读《编写可维护的JavaScript》第一章总结
第一章 基本的格式化
1.4 ① 换行
当一行长度到达了单行最大的字符限制时,就需要手动将一行拆成俩行。通常我们会在运算符后换行,下一行会增加俩个层级的缩进。
// 好的做法: 在运算符后换行,第二行追加俩个缩进
callFunction(document, element, window, "some string value", true, 123,
navigator); // 不好的做法: 在运算符之前换行了
callFunction(document, element, window, "some string value", true, 123
, navigator)
目的: 防止ASI(Automatic Semicolon Insertion)机制会在某些场景下在行结束的位置插入分号。总是将一个运算符置于行尾, ASI就不会自作主张地插入分号,也就避免了错误的发生。
1.5 ② 空行
代码看起来应当像一系列可读的段落,而不是一段柔在一起的连接文本。有时一段代码的语义和另一段代码不相关,这时就应该使用空行将它分隔。
1.6 ③ 命名
JavaScript语言的核心ECMAScript,即是遵照了驼峰式大小写(Camel case)命名法。驼峰式大小写命名法是由小写字母开始的,后续每个单词首字母都大写。
var thisIsMyName; var anotherVariable; var aVeryLongVariableName;
1.6.1 ④ 变量和函数
变量名应当总是遵守驼峰式大小写命名法,并且命名前缀是名词。函数名前缀应当是动词。对于函数和方法命名来说,第一个单词应该是动词,这里有一些使用动词常见的约定:
动词 | 含义 |
can | 函数返回一个布尔值 |
has | 函数返回一个布尔值 |
is | 函数返回一个布尔值 |
get | 函数返回一个非布尔值 |
set | 函数用来保存一个值 |
// 好的写法
var count = 10;
var myName = "Nicholas";
var found = true; // 不好的写法:变量看起来像函数
var getCount = 10;
var isFound = true; // 好的写法
funciton getName(){
return myName;
} // 不好的写法
function theName(){
return myName;
}
1.6.3 ⑤ 构造函数
在JavaScript中,构造函数只不过是前面冠以new运算符的函数,用来创建对象,构造函数的命名遵守大驼峰命名法(Pascal Case)。
Pascal Case和 Camel Case都表示”驼峰大小写“,二者的区别在于Pascal Case以大写字母开始。因此anotherName可以替换成AnotherName。这样做可以将构造函数从变量和普通函数中区分出来。构造函数的命名也常常是名词,因为它们是用来创建某个类型的实例的。
// 好的写法
function Person(name){
this.name = name;
}
Person.prototype.sayName = function(){
alert(this.name);
}
var me = new Person("Nicholas");
1.7.1 ⑥ 直接量
在JavaScript中,字符串是独一无二的。字符串可以用双引号括起来,也可以用单引号括起来。
// 合法的JS代码
var name = "Nicholas says,\"Hi.\"";
// 也是合法的JS代码
var name='Nicholas says, "Hi"'
你需要关心的是:你的代码应当从头到尾只保持一种风格。
关于字符串还有另外一个问题需要注意,创建多行字符串。
// 不好的写法
var longSring = "Here 's the stroy, of a man \
named Bradyh"
// 好的写法
var longString = "Here's the story, of a man " +
"name Bradyh"
多行字符串的一种替代写法:使用字符串连接符(+)将字符创分成多份。
1.7.3 ⑦ null
null是一个特殊值,但我们常常误解它,将它和undefined搞混。在下列场景中应当使用null。
- 用来初始化一个变量,这个变量可能赋值为一个对象。
- 用来和一个已经初始化的变量比较,这个变量可以是可以不是一个对象。
- 当函数的参数期望是对象时,用作参数传入。
- 当函数的返回值是对象时,用作返回值传出。
还有下面一些场景不应当使用null.
- 不要使用null来检测是否传入了某个参数。
- 不要使用null来检测一个未初始化的变量。
// 好的写法
var person = null; // 好的写法
function getPerson() {
if (condition) {
return new Person("Nicholas");
} else {
return null;
}
}
// 好的写法
var person =getPerson();
if (person != null) {
doSomething();
}
// 不好的写法:用来和未初始化的变量比较
var person;
if (person != null) {
doSomething();
}
// 不好的写法:检测是否传入了参数
function doSomething(arg1, arg2, arg3, arg4) {
if (arg4 != null) {
doSomethingElse();
}
}
1.7.5 ⑧ 对象直接量
// 不好的写法
var book=new Object();
book.title = "Maintainable JavaScript";
book.author = "Nicholas C. Zakas";
// 好的写法
var book = {
title:"Maintainable JavaScript",
author:"Nicholas C. Zakas"
};
// 不好的做法
var colors = new Array("red", "green", "blue");
var numbers = new Array(, , , );
// 好的做法
var colors = ["red", "green", "blue"];
var numbers = [, , , ];
读《编写可维护的JavaScript》第一章总结的更多相关文章
- [已读]编写可维护的javascript
13年4月份出版,作者是大名鼎鼎的Zakas,他的另两本书<javascript高级程序设计>与<高性能javascript>你一定听过或者读过. 这本书重点讲了编码风格和编码 ...
- 【读书笔记】读《编写可维护的JavaScript》 - 编程实践(第二部分)
本书的第二个部分总结了有关编程实践相关的内容,每一个章节都非常不错,捡取了其中5个章节的内容.对大家组织高维护性的代码具有辅导作用. 5个章节如下—— 一.UI层的松耦合 二.避免使用全局变量 三.事 ...
- 拯救一切强迫症 - 读《编写可维护的 JavaScript》(一)
拯救一切强迫症 - 读<编写可维护的 JavaScript>(一) 本文写于 2020 年 4 月 24 日 我在小学的时候就有接触过编程,所以读大一的时候 C 语言还算是轻车熟路.自然会 ...
- 编写可维护的JavaScript 收纳架
如果你看过Nicolas C.Zakas写过的任何作品,你必须承认他是个不折不扣的天才.也只有天才级的才能写出<JavaScript高级程序设计>让所有的前端攻城师人手一本.Nicolas ...
- 《编写可维护的JavaScript》之编程实践
最近读完<编写可维护的JavaScript>,让我受益匪浅,它指明了编码过程中,需要注意的方方面面,在团队协作中特别有用,可维护性是一个非常大的话题,这本书是一个不错的起点. 本书虽短,却 ...
- 编写可维护的Javascript读书笔记
写在前面:之前硬着头皮参加了java方面的编程规范培训,收货良多,工作半年有余的时候,总算感觉到一丝丝Coding之美,以及造轮子的乐趣,以至于后面开发新功能的时候,在Coding style方面花了 ...
- 《编写可维护的javascript》读书笔记(中)——编程实践
上篇读书笔记系列之:<编写可维护的javascript>读书笔记(上) 上篇说的是编程风格,记录的都是最重要的点,不讲废话,写的比较简洁,而本篇将加入一些实例,因为那样比较容易说明问题. ...
- 《编写可维护的javascript》读书笔记(上)
最近在读<编写可维护的javascript>这本书,为了加深记忆,简单做个笔记,同时也让没有读过的同学有一个大概的了解. 一.编程风格 程序是写给人读的,所以一个团队的编程风格要保持一致. ...
- 编写可维护的JavaScript之编程风格
在团队中只有每个人的编程风格一致,大家才能方便的互相看懂和维护对方的代码. 1. 层级缩进 对于层级缩进目前有两种主张:1)使用制表符这种方法有两种好处,第一,制表符和缩进层级之间是一一对应关系,符合 ...
- 编写可维护的JavaScript代码(部分)
平时使用的时VS来进行代码的书写,VS会自动的将代码格式化,所有写了这么久的JS代码,也没有注意到这些点.看了<编写可维护的javascript代码>之后,做了些笔记. var resul ...
随机推荐
- 【iCore3 双核心板_FPGA】例程十:锁相环实验——锁相环使用
实验指导书及代码包下载: http://pan.baidu.com/s/1boeODjx iCore3 购买链接: https://item.taobao.com/item.htm?id=524229 ...
- nginx优化 突破十万并发
一.一般来说nginx 配置文件中对优化比较有作用的为以下几项: 1. worker_processes 8; nginx 进程数,建议按照cpu 数目来指定,一般为它的倍数 (如,2个四核的cpu ...
- 【整理】虚拟机和主机ping不通解决办法
检查几个方面: 1.检查虚拟网卡有没有被禁用2.检查虚拟机与物理机是否在一个VMNet中3.检查虚拟机的IP地址与物理机对应的VMNet是否在一个网段4.检查虚拟机与物理机的防火墙是否允许PING, ...
- 移动端html页面布局
记录一下: ---------- 如果设计稿尺寸为 : 96px: 1. rem html{ font-size:62.5%; } 的情况下 : 4.8rem: 2. rem html{ font-s ...
- grep 常用参数详解
grep常用参数详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 刚刚和同事打完球,虽然自己输了~不过也蛮好玩的,好久没有玩过乒乓球啦,话说你喜欢玩乒乓球吗?好啦,话不多说说,让 ...
- 什么是FOUC?如何避免FOUC?///////////////////////////zzzz
一个新的名词叫做 FOUC 浏览器样式闪烁,之前也听说过一些类似的东西,比如样式突变等等,但这东西竟然有学名的..什么是FOUC(文档样式短暂失效)?如果使用import方法对CSS进行导入,会导致 ...
- Redis linux 下安装 及扩展配置
1.首先在/usr/local/ 创建文件夹 reids Cd /usr/local/ mkdir redis 2.把redis安装包放在redis目录下面进行解压phpredis-2.2.4.tar ...
- 【转】赞一下huicpc035
以下转自:http://hi.baidu.com/fpkelejggfbfimd/item/99421eaefa93a814a9cfb722 本来以为HNU的huicpc035和我一样退役了,后来听说 ...
- LINUX 自动备份脚本文件
首先我在/root/backup 目录下建立一个文件夹, #mkdir /root/backup/mysqlbackup 以后在每天五点钟,就会有一个文件保存在这里. 接着新建文件 #vim /roo ...
- URL中文乱码处理总结(转)
转自:http://www.cnblogs.com/xirongliu/archive/2012/09/06/2674196.html 问题:传递中文参数的时候,接收页面出现乱码问题?当跨域操作,两套 ...