资讯专栏INFORMATION COLUMN

《前端架构设计》读后笔记

Ocean / 3069人阅读

摘要:作为一名前端架构师,你的工作是不断地探索和评估新的技术平台方法和框架。世界上没有一刀切式的解决方案,而前端架构师的使命正是将项目的需求与前端开发的实际情况相结合。

做前端工作一段时间了,也写了不少的项目。但是突然好像快要失去了兴趣。美工、后台、项目经理、测试等人员多层夹击。美工说就这么设计,你就得完全按着来。后台说这个需求做不了,得那样做,于是已经做好的页面推倒重来。测试说,这样做更符合大众习惯,这样的流程才正确。于是,一遍遍地改,没有话语权。就这样兴趣被慢慢磨灭着...。直到我看到了这本书。兴趣的小火苗又开始突突的窜了起来.
这本书把前端结构师,比喻成建筑工程师。都在一层层的搭建着自己的产品。这个产品有着完善的可遵循的体系设计、有着流畅运转的工作规划、有着持续优化的监督跟进。想象一下,我们亲手编码(绘制)的产品,大家都能看到,能为大家的生活带来些许的变化,甚至为之惊叹,那将是件多么美好的事情。
那什么是前端架构呢?
本书作者定义为:前端架构是一系列工具和流程的集合,旨在提升前端代码的质量,并实现高效、可持续的工作流。
作为一名前端架构师,你的工作是不断地探索和评估新的技术、平台、方法和框架。世界上没有一刀切式的解决方案,而前端架构师的使命正是将项目的需求与前端开发的实际情况相结合。
那怎么来实现一个好的前端架构呢?
本书作者认为应围绕四个核心来工作:
(1)代码
(2)流程
(3)测试
(4)文档

一、代码

作为前端架构师,你需要评估标记产生的过程。你对内容的顺序、使用的元素和 CSS 类名有多大的控制权?这些元素在将来改动起来会有多大难度?模板是否易用,或者是否只有后端开发人员才能更改?甚至,你的标记全是基于模板系统的吗?你可以通过系统做出更改,还是需要手动处理?通过回答这些问题,来不断优化自己的代码。同时要意识到我们的工作不是单纯地实现,某个页面,而是设计整个系统。
通过BEM原则模块化一个简单的导航,代码如下:

1、模块化CSS有几种方法:
(1)OOCSS(Object-Oriented CSS,面向对象的 CSS)方法:
OOCSS(http://oocss.org/)有两个主要的原则:分离结构和外观,以及分离容器和内容。

Title 1

...
...

(2)SMACSS(Scalable and Modular Architecture for CSS,模块化架构的可扩展 CSS)方法

Title 1

...
...

(3)BEM(Block Element Modifier,块元素修饰符)方法
包括块名、元素和修饰符。BEM 使用非常简洁的约定来创建 CSS 类名,而这些字符串可能会相当长。元素名加在双下划线后(例如 toggle__details),修饰符加在双横杠后(如 toggle__details--active)。这里的 details 是元素,active 是修饰符,这个约定使得 CSS 类名非常清晰。使用双横杠是为了避免块名被混淆为修饰符。

Title 1

2、css采取原则:
(1)分离容器和内容

(2)区分布局与组件的角色和职责

(3)在标记上使用单一、扁平的选择器

(4)使用其他原则,比如单一职责原则、单一样式来源、内容修饰符
单一职责原则:规定你创建的所有东西必须有单一的、高度聚焦的理由。你应用到某个选择器里的样式应该是为了单一目的而创建的,并且能够很好地实现这个目标。
单一样式来源:在一个模块化设计中,任何组件的设计必须由组件本身决定,而不应该被它的父类名限制。
组件修饰符:让你能够定义一个组件在多个不同情况下的多种变化。

3、js的原则

(1)保持代码整洁:使用JS Hint
(2)创造可复用的函数

二、流程

(1)工作流
(2)任务处理流

三、测试

(1)单元测试
(2)性能测试
(3)视觉还原测试

四、文档

(1)样式文档
使用SassDoc来自动化生成sass文档。
(2)图形库
使用Brad Frost 的原子设计原则(http://patternlab.io)来生成图形库

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/94789.html

相关文章

  • 《Java编程思想》读后总结(一)

    摘要:前言编程思想这本书,陆陆续续读了年,终于基本都浏览了一遍。每个对象对外暴露接口,程序通过对象暴露的接口向对象发送消息,获取该对象的服务能力。异常处理异常处理,为编写程序阶段提供了一种预见性的防止程序崩溃的出路。 前言 《Java编程思想》这本书,陆陆续续读了1年,终于基本都浏览了一遍。通过这本书,试图理解作者的想法,才真的体会到Java思想。感谢本书的作者,不仅讲述了java的语法,更...

    hufeng 评论0 收藏0
  • 代码之髓读后感——如何高效的学习语言

    摘要:代码之髓读后感如何高效的学习语言技术读后感王垠如何掌握程序语言代码之髓这本书里提出了三种学习语言的方法如何高效的学习语言在比较中学习在历史中学习在实践中学习在比较中学习通过比较多种语言,总结出某种语言的独有特点,以及多种语言的共有特点。 title: 代码之髓读后感——如何高效的学习语言date: 2017-07-08 17:17:00categories: 技术tags: 读后感 ...

    ivyzhang 评论0 收藏0
  • 两篇文章读后感, 关于数据库, 关于 MVC, 也关于 React

    摘要:两篇文章今天看了两篇文章我觉得对我的影响会很大当然都是相关的一篇是在大会上的演讲有视频也有文字版关于数据库另一篇是关于的文章从上看到的关于架构来源前面一篇是在的文档上看到的这文档上有不少我关心的技术的作者最近在上 两篇文章 今天看了两篇文章, 我觉得对我的影响会很大, 当然, 都是 React 相关的: 一篇是 Martin Kleppmann 在 Strangeloop 2014...

    BenCHou 评论0 收藏0
  • Java技术转(兼顾)产品经理——读《快速转行做产品经理》有感

    摘要:第四章总结最后的章节其实是一些自学路上的建议与避免小白走错路的坑。结语感谢作者的分享,也看出作者在行业的丰富经验,同时此书确实很适合小白阅读,阅读轻松而且没有太多专业性词汇,让很多人都能对有一个大致的概念。 博客 猫叔的博客 前言 年前部门一次性购买了一批书,我知道这次我应该会被指派阅读一些偏向于管理类的书籍,但是没想到美女领导直接给了我这本书《快速转行做产品经理》,其实一开始我有点...

    MockingBird 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<