JS编程最佳实践
最近花了一周时间把《编写可维护的js》 阅读了一遍, 现将全书提到的JS编程最佳实践总结如下, 已追来者!
1.return 之后不可直接换行, 否则会导致ASI(自动分号插入机制)会在return 后插入一个分号。
2.一行语句最多不超过80个字符, 如果超过则应该在运算符后换行,并且追加两个缩进。
3.采用驼峰式命名,变量前缀为名词如:myName 函数应该以动词开始如:getName,常量应该以大写字母命名,如:MAX_COUNT, 构造函数首字母大写。
4.数字的写法: 整数:count =10 小数 count =10.0; 十六进制写法0xA2 科学计数法1e23 不推荐使用八进制写法。
5.如下场景应该使用null:
1. 为可能赋值为对象的变量初始化。
2. 在函数中, 如果参数期望是对象, 当做参数传入, 返回值同理。
6.如下场景不应该使用null:
1.检测参数是否传入。
2.检测未初始化的变量。
7.null应该当做是对象的占位符。
8.undefine应该避免使用。
9.声明对象和数组使用字面量直接量。如 var arry =[1,2,3];
10.case语句应该以break结尾。
11.禁止使用with语句。
12.fo-in循环会遍历对象以及对象原型的属性,所以应该使用hasOwnProperty()来过滤掉原型属性。如果需要遍历原型的属性, 应该加上注释。
13.数组应该使用 for循环 遍历。
14.尽量避免变量提升。
15.不要使用全局的严格模式, 尽量在函数中使用。
16.推荐使用 === 来比较
17.禁止使用eval() 和Function
18.禁止使用 String Name 这样的原始包装类型来创建新对象。 例如 var name = new String("name");
19.当需要通过JS来修改样式时, 应该操作className。推荐使用html5的方法:ele.classList.add("className");
20.避免使用全局变量。推荐以一下几种方式替代:
1.创建唯一的全局对象。
2.创建命名空间
3.以函数形式封装起来。
21.事件处理有两个原则:
1.隔离应用逻辑
2.不要分发事件对象。
用例:
var myApp = {
handlClick:function(event)
{
this.show(event.clientX, event.clientY);//杜绝分发事件对象
}
}; addListener(ele,"click, function(event){
myApp.handlClick(event); //与应用层隔离
}
22.避免 与null比较, 除非确实需要与null比较。应该使用typeof, typeof也不应该对null进行检测。
23.检测引用值应该使用value instanceof constructor
24.检测数组使用isArry()方法
25.检测属性应该使用in 关键字 if("cout" in object){}; ie8以下不支持 可以使用hasOwnProperty();
26.配置数据应该与应用程序抽离出来, 最好形成单独的配置文件。
27.多人开发项目中对于对象的处理遵循以下几条原则:
1.如果不是自己创建的对象,不要修改他们, 包括:原生对象, DOM对象, BOM对象, 类库对象。
2.已经存在的对象,(别人创建的对象), 不覆盖方法, 不新增方法, 不删除方法。
JS编程最佳实践的更多相关文章
- 思索 p5.js 的最佳实践
思索 p5.js 的最佳实践 本文写于 2020 年 12 月 18 日 p5.js 是一个 JavaScript 库,用于为艺术家.设计师提供更容易上手的创意编程. 它有着完整的一套基于 Canva ...
- Java 网络编程最佳实践(转载)
http://yihongwei.com/2015/09/remoting-practice/ Java 网络编程最佳实践 Sep 10, 2015 | [Java, Network] 1. 通信层 ...
- Atitit.angular.js 使用最佳实践 原理与常见问题解决与列表显示案例 attilax总结
Atitit.angular.js 使用最佳实践 原理与常见问题解决与列表显示案例 attilax总结 1. 本文范围 1 2. Angular的优点 1 2.1. 双向数据绑定 1 2.2. dsl ...
- vue.js+boostrap最佳实践
一.为什么要写这篇文章 最近忙里偷闲学了一下vue.js,同时也复习了一下boostrap,发现这两种东西如果同时运用到一起,可以发挥很强大的作用,boostrap优雅的样式和丰富的组件使得页面开发变 ...
- C 编程最佳实践(书写风格)
简介本文是为了满足开发人员的需要而写的.我们总结了一套指南,无论作为开发人员还是顾问,这些指南多年来一直都很好地指导着我们,我们把它们作为建议提供给您,希望对您的工作有所帮助.您也许不赞同其中的某些指 ...
- 一些通过SAP ABAP代码审查得出的ABAP编程最佳实践
1. 这两个IF ELSE分支里检测的条件其实逻辑上来说都是同一类,应该合并到一个IF分支里进行检查: It is an expensive operation to open a file in a ...
- jQuery编程最佳实践笔记
优化选择器 选择器优化已经不如从前那么重要,因为更多的浏览器实现了document.querySelectorAll()方法,所以选择的重担由jQuery转移到了浏览器. 但是仍然有一些技巧是需要 ...
- Shell 脚本编程最佳实践
前言 由于工作需要,最近重新开始拾掇shell脚本.虽然绝大部分命令自己平时也经常使用,但是在写成脚本的时候总觉得写的很难看.而且当我在看其他人写的脚本的时候,总觉得难以阅读.毕竟shell脚本这个东 ...
- require.js 最佳实践【转】
https://www.cnblogs.com/digdeep/p/4607131.html require.js是一个js库,相关的基础知识,前面转载了两篇博文:Javascript模块化编程(re ...
随机推荐
- 设计模式 之 Organizing the Catalog 组织目录
Design patterns vary in their granularity and level of abstraction. Because thereare many design pat ...
- 关于onpropertychange与oninput的兼容问题
关于onpropertychange与oninput的用法,网上一大堆,但还是有不兼容的时候,比如说,我想计下,一个input的值改变了多少次,如果写成兼容写法就为 <!doctype html ...
- Java异常基础Exception
异常指不期而至的各种状况,如:文件找不到.网络连接失败.非法参数等.异常是一个事件,它发生在程序运行期间,干扰了正常的指令流程.Java通 过API中Throwable类的众多子类描述各种不同的异常. ...
- Sumsets(POJ 2229 DP)
Sumsets Time Limit: 2000MS Memory Limit: 200000K Total Submissions: 15293 Accepted: 6073 Descrip ...
- BC 65 ZYB's Premutation (线段树+二分搜索)
题目简述:有一个全排列,一直每个前缀区间的逆序对数,还原这个排列. fi记录逆序对数,pi记录该位置数值,则k=fi-f(i-1)表示前i-1个数比pi大的数的个数,那么只要在剩余元素求出按大小顺序第 ...
- C/C++语言学习——内存分配管理
1.一个由C编译的程序占用的内存分为以下几个部分 1.栈区(stack)— 程序运行时由编译器自动分配,存放函数的参数值,局部变量的值等.其操作方式类似于数据结构中的栈.程序结束时由编译器自动释放. ...
- Eight(South Central USA 1998)(八数码) 分类: bfs 2015-07-05 22:34 1人阅读 评论(0) 收藏
The 15-puzzle has been around for over 100 years; even if you don't know it by that name, you've see ...
- devStack
1,devstack shell 脚本开源官网 http://devstack.org/ 脚本功能快速搭建 OpenStack 的运行和开发环境 [Note tips by Ruiy devstack ...
- hibernate多对一的操作解析
在hibernate的关联操作中有很多关系,其中多对一关系是最常见的.我们看这两个表. 这里有部门表和员工表. 那么我们可以这么说一个部门可以有多个员工.这就是1对多的关系.这是我们站在部门表的角度上 ...
- 【转】C++容器类
C++容器类 C++中的容器类包括“顺序存储结构”和“关联存储结构”,前者包括vector,list,deque等:后者包括set,map,multiset,multimap等. 若需要存储的元素数在 ...