读书笔记:编写可维护的javascript

  1. 使用for-in循环的时候,要使用hasOwnProperty方法进行过滤,除非你想查找原型链上的继承属性
  2. 不应当使用for-in循环进行数组遍历,而只应该对object的属性进行遍历
  3. 每行表达式的结尾要使用分号(;),为了使压缩包能正常工作,还应该为每个js文件的开头加上分号,形如这样的匿名函数定义;(function(){...}());
  4. 变量初始化应该赋值null, 因为typeof这种操作符,对于未初始化的变量返回的是object,而未声明的变量返回undefine
  5. null==undefined的结果是true,而null===undefined的结果是false,因此我们应该使用===,!==
  6. 不要直接在object构造对象上附加属性,而要通过json格式的表示法来初始化一个对象
  7. 函数体中所有变量的声明会被解析器提前到第一句执行语句前,因为js引擎执行函数时会首先扫描作用域内的所有的变量,无论它放在函数体何处
  8. 虽然所有的声明会被提前,而且函数声明优先级高于同名的变量声明,但只要变量在声明的同时进行了初始化,那函数声明就无法再覆盖了
  9. 函数声明不应放在代码块中间或后面,尤其是判断条件的里面,不同的浏览器对此的解释是不同的,但把匿名函数赋值给表达式的声明方式不适用此规则
  10. 不要使用eval,也不要在Function,setTimeout,setInterval等函数中传入字符串
  11. 不要在css中嵌入javascript表达式,这会导致浏览器的重复计算,从而使得系统的整体性能下降,而且这种把js渗入到css中的做法不值得提倡
  12. 不要在javascript中操作对象的css样式。相比上一条,这一条更容易犯错,因为我们经常会在Dom元素中修改style属性
  13. 将css与js分离,同时又能保持相互之间的联系的秘诀就是js只负责操作css的className,而把className的样式定义放在css中
  14. 不要在html中直接嵌入javascript代码片段,而要把javascript代码放入单独的js文件中,使用<script>引用外部文件的方式
  15. 不要在javascript中直接嵌入html代码,使用javascript模板引擎,然后通过变量进行渲染会更好一点
  16. handlebars是一款优秀的javascript模板引擎,它能帮你实现模板+变量=动态html,在ember等前端框架中也有使用
  17. 处理javascript全局变量冲突问题的方法有两种
    1. 一是使用单全局变量
      1. 即一个应用系统的所有内部变量置于某一个全局变量之下,而这个全局变量要位于javascript引擎的上下文环境中
      2. javascript的内置对象,比如Array,Date等,你可以把它们看成是一个单全局变量,因为这些变量几乎在每个应用中都可能使用
      3. 单全局变量的应用要涉及到命名空间的划分和模块的加载
      4. 对于模块加载,可以使用使用AMD(异步模块定义),它提供了全局函数define用于加载依赖模块
      5. 想要使用AMD,需要有与之兼容的模块加载器,比如RequireJS,http://www.requirejs.org/
      6. requireJS提供了一个require全局函数,用来加载模块和执行加载成功后的方法回调
    2. 二是使用零全局变量
      1. 零全局变量的使用,主要是通过匿名函数的即时调用来实现
      2. 虽然零全局变量不会造成全局污染,但通常使用的场景有限
      3. 一般用于页面初始加载,或者需要某段一次性执行的代码,而且它与其它代码无交互,也不对外输出接口
  18. 处理事件时,要将事件处理逻辑和应用逻辑分离,event对象永远只被事件处理逻辑所持有,应用逻辑不要直接访问event对象
  19. 采用typeof运算符检测基本类型,用instanceof检测引用类型,用===检测null
  20. 检测函数:typeof myFunc === "function"
  21. 检测数组:Array.isArray(myArray)
  22. 检测属性:myAttr in myObject, Object.hasOwnProperty
  23. 由于js解析器不会保护任何代码包括执行环境,所以应用开发人员不应该修改除自己代码以外的其它任何代码,这包括js的原生类型,DOM,BOM以及第三方类库,如jQuery等
  24. Ant也可以用作javascript的构建工具


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
编写维护JavaScript》向开发人员阐述了如何在团队开发中编写具备高可维护性的JavaScript代码,书中详细说明了作为团队一分子,应该怎么写JavaScript。本书内容涵盖了编码风格、编程技巧、自动化、测试等几方面,既包括具体风格和原则的介绍,也包括示例和技巧说明,最后还介绍了如何通过自动化的工具和方法来实现一致的编程风格。   《编写维护JavaScript》作者Nicholas C. Zakas是顶级的Web技术专家,也是《JavaScript高级程序设计》一书的作者。他曾是Yahoo!的首席前端开发工程师,在完成了从一名“独行侠”到“团队精英”的蜕变后,他站在前端工程师的角度提炼出众多的最佳编程实践,其中包括很多业内权威所推崇的最佳法则,而这些宝贵经验正是本书的核心内容。   《编写维护JavaScript》适合前端开发工程师、JavaScript程序员和学习JavaScript编程的读者阅读,也适合开发团队负责人、项目负责人阅读。运用本书中讲述的技巧和技术,可以使JavaScript团队编程从侠义的个人偏好的阴霾走出来,走向真正的高可维护性、高效能和高水准。 第一部分 编程风格 第1章 基本的格式化 1.1 缩进层级 1.2 语句结尾 1.3 行的长度 1.4 换行 1.5 空行 1.6 命名 1.6.1 变量和函数 1.6.2 常量 1.6.3 构造函数 1.7 直接量 1.7.1 字符串 1.7.2 数字 1.7.3 null 1.7.4 undefined 1.7.5 对象直接量 1.7.6 数组直接量 第2章 注释 2.1 单行注释 2.2 多行注释 2.3 使用注释 2.3.1 难于理解的代码 2.3.2 可能被误认为错误的代码 2.3.3 浏览器特性hack 2.4 文档注释 第3章 语句和表达式 3.1 花括号的对齐方式 3.2 块语句间隔 3.3 switch语句 3.3.1 缩进 3.3.2 case语句的“连续执行” 3.3.3 default 3.4 with语句 3.5 for循环 3.6 for-in循环 第4章 变量、函数和运算符 4.1 变量声明 4.2 函数声明 4.3 函数调用间隔 4.4 立即调用的函数 4.5 严格模式 4.6 相等 4.6.1 eval() 4.6.2 原始包装类型 第二部分 编程实践 第5章 UI层的松耦合 5.1 什么是松耦合 5.2 将JavaScript从CSS中抽离 5.3 将CSS从JavaScript中抽离 5.4 将JavaScript从HTML中抽离 5.5 将HTML从JavaScript中抽离 5.5.1 方法1:从服务器加载 5.5.2 方法2:简单客户端模板 5.5.3 方法3:复杂客户端模板 第6章 避免使用全局变量 6.1 全局变量带来的问题 6.1.1 命名冲突 6.1.2 代码的脆弱性 6.1.3 难以测试 6.2 意外的全局变量 避免意外的全局变量 6.3 单全局变量方式 6.3.1 命名空间 6.3.2 模块 6.4 零全局变量 第7章 事件处理 7.1 典型用法 7.2 规则1:隔离应用逻辑 7.3 规则2:不要分发事件对象 第8章 避免“空比较” 8.1 检测原始值 8.2 检测引用值 8.2.1 检测函数 8.2.2 检测数组 8.3 检测属性 第9章 将配置数据从代码中分离出来 9.1 什么是配置数据 9.2 抽离配置数据 9.3 保存配置数据 第10章 抛出自定义错误 10.1 错误的本质 10.2 在JavaScript中抛出错误 10.3 抛出错误的好处 10.4 何时抛出错误 10.5 try-catch语句 10.6 错误类型 第11章 不是你的对象不要动 11.1 什么是你的 11.2 原则 11.2.1 不覆盖方法 11.2.2 不新增方法 11.2.3 不删除方法 11.3 更好的途径 11.3.1 基于对象的继承 11.3.2 基于类型的继承 11.3.3 门面模式 11.4 关于Polyfill的注解 11.5 阻止修改 第12章 浏览器嗅探 12.1 User-Agent检测 12.2 特性检测 12.3 避免特性推断 12.4 避免浏览器推断 12.5 应当如何取舍 第三部分 自动化 第13章 文件和目录结构 13.1 最佳实践 13.2 基本结构 第14章 Ant 14.1 安装 14.2 配置文件 14.3 执行构建 14.4 目标操作的依赖 14.5 属性 14.6 Buildr项目 第15章 校验 15.1 查找文件 15.2 任务 15.3 增强的目标操作 15.4 其他方面的改进 15.5 Buildr任务 第16章 文件合并和加工 16.1 任务 16.2 行尾结束符 16.3 文件头和文件尾 16.4 加工文件 第17章 文件精简和压缩 17.1 文件精简 17.1.1 使用YUI Compressor精简代码 17.1.2 用Closure Compiler精简 17.1.3 使用UglifyJS精简 17.2 压缩 17.2.1 运行时压缩 17.2.2 构建时压缩 第18章 文档化 18.1 JSDoc Toolkit 18.2 YUI Doc 第19章 自动化测试 19.1 YUI Test Selenium引擎 19.1.1 配置一台Selenium服务器 19.1.2 配置YUI Test Selenium引擎 19.1.3 使用YUI Test Selenium引擎 19.1.4 Ant的配置写法 19.2 Yeti 19.3 PhantomJS 19.3.1 安装及使用 19.3.2 Ant的配置写法 19.4 JsTestDriver 19.4.1 安装及使用 19.4.2 Ant的配置写法 第20章 组装到一起 20.1 被忽略的细节 20.2 编制打包计划 20.2.1 开发版本的构建 20.2.2 集成版本的构建 20.2.3 发布版本的构建 20.3 使用CI系统 20.3.1 Jenkins 20.3.2 其他CI系统 附录A JavaScript编码风格指南 附录B JavaScript工具集

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值