读《编写可维护的JavaScript》第11章总结
这周也是拿到了同程的offer,从此走上了前端之路!感谢我的贵人们。再次纪念一下~!
第11章 不是你的对象不要动
11.1 什么是你的
你的对象:当你的代码创建了这些对象或者你有职责维护其他人的代码的对象时,你就拥有这些对象。
不是你的对象:
- 原生对象(Object、Array等等)
- DOM对象(例如:Document)
- 浏览器对象模型(BOM)对象(例如: window)
- 类库的对象
11.2.1 不覆盖方法
JavaScript这门语言也存在着糟粕,那就是覆盖一个已经存在的方法是难以置信的容易- -即使那个神圣的 document.getElementById()方法也不例外。
// 不好的写法
document.getElementById = function() {
return null; //引起混乱
}
所以这里不做更多的例子,作者以自己的亲身经历告诉我们:不覆盖方法才是明智的选择。
11.2.2 不新增方法
作者举了个Prototype JavaScript类库的发展历史的例子说明了:不新增方法同样也是明智的选择。
11.2.3 不删除方法
删除一个方法有俩种手段:
1、把方法赋值为null
2、使用delete操作符来删除,但是它只能在对象的实例和方法起作用,如果在prototype的属性和方法上使用delete是不起作用的
作者也十分干脆:删除一个已存在对象的方法是糟糕的实践。
11.3 更好的途径
更好的方法就是不直接修改这些对象,而是扩展它,也就是我们通常所说的继承。
JavaScript中有俩种基本的继承方式:基于对象的继承和基于类型的继承。
① 基于对象的继承
ECMAScript5中Object.create()方法是实现这种继承的最简单的方式(如果你不熟悉,《JS权威指南》第121页有详解):
var person = {
name : "Nicholas",
sayName : function() {
alert(this.name);
}
};
var myPerson = Object.create(person);
myPerson.sayName(); // 弹出"Nicholas"
原理:Object.create这个方法会返回一个空函数的实例,这个空函数的原型属性(prototype)是person。同时myPerson.prototype指向了空对象的prototype, 这个空对象的prototype也就是person, 所以当在myPerson上调用sayName函数时,Js会顺着它的原型链向上查找并调用方法。
同时也推荐和感谢慕课网的Bosn老师对于原型和继承这方面的独到、深刻、犀利的讲解!
② 基于类型的继承
基于类型的继承和基于对象的继承工作方式是差不多的,它从一个已存在的对象继承,这里的继承是依赖与原型的。因此,基于类型的继承是通过构造函数实现的,而非对象。这意味着,需要访问被继承对象的构造函数。
function MyError(message) {
this.message = message;
}
MyError.prototype = new Error();
// MyError类继承自Error(所谓的超类)。给MyError.prototype赋值为一个Error的实例。然后,每个MyError实例从Error那里继承它的属性和方法, instanceof也能正常工作。
var error = new MyError("Something bad happened.");
console.log(error instanceof Error);
console.log(error instanceof MyError);
11.5 阻止修改
ECMAScript5引入了几个方法来防止对对象的修改。可以做到这样的事情:锁定这些对象,保证任何人不能有意无意地修改他们不想要的功能。以下三种修改的级别:
· 防止扩展 ( preventExtension())
禁止为对象“添加”属性和方法,但已存在的属性和方法是可以被修改或删除的
· 密封 ( seal() )
类似“防止扩展”,而且禁止为对象“删除”已存在的属性和方法
· 冻结 ( freeze() )
类似密封,而且禁止为对象“删除”已存在的属性和方法
每种锁定的类型都拥有俩个方法:一个用来实施操作,另一个用来检测是否应用了相应的操作。
下面的例子中,锁定了prevent对象防止被扩展,所以调用Object.isExtensible()函数返回false,试图为person对象扩展新增属性或方法将会悄无声息的失败。在严格模式下,试图为一个不可扩展的对象新增任何属性或方法都将会抛出一个错误。
var person = {
name : "Nicholas"
};
// 锁定对象
Object.preventExtension(person);
console.log(Object.isExtensible(person)); //false
person.age = 25; //正常情况悄悄地失败,除非在strict模式下抛出错误
原理同上面相似,下面是Object.seal()函数
// 锁定对象
Object.seal(person);
console.log(Object.isExtensible(person)); // false
console.log(Object.isSealed(person)); // true
delete person.name; // 正常情况悄悄地失败,除非在strict模式下抛出错误
person.age = 25; // 同上
使用Object.freeze()函数来冻结一个对象。可以使用Object.isFrozen()函数来检查一个对象是否已被冻结。
// 锁定对象
Object.freeze(person);
console.log(Object.isExtensible(person)); // false
console.log(Object.isSealed(person)); // true
console.log(Object.isFrozen(person)); // true
person.name = "Greg"; // 正常情况下悄悄地失败,除非在strict模式下抛出错误
person.age = 25; // 同上
delete person.name; //同上
读《编写可维护的JavaScript》第11章总结的更多相关文章
- 读《编写可维护的JavaScript》第一章总结
第一章 基本的格式化 1.4 ① 换行 当一行长度到达了单行最大的字符限制时,就需要手动将一行拆成俩行.通常我们会在运算符后换行,下一行会增加俩个层级的缩进. // 好的做法: 在运算符后换行,第二行 ...
- [已读]编写可维护的javascript
13年4月份出版,作者是大名鼎鼎的Zakas,他的另两本书<javascript高级程序设计>与<高性能javascript>你一定听过或者读过. 这本书重点讲了编码风格和编码 ...
- 【读书笔记】读《编写可维护的JavaScript》 - 编程实践(第二部分)
本书的第二个部分总结了有关编程实践相关的内容,每一个章节都非常不错,捡取了其中5个章节的内容.对大家组织高维护性的代码具有辅导作用. 5个章节如下—— 一.UI层的松耦合 二.避免使用全局变量 三.事 ...
- 拯救一切强迫症 - 读《编写可维护的 JavaScript》(一)
拯救一切强迫症 - 读<编写可维护的 JavaScript>(一) 本文写于 2020 年 4 月 24 日 我在小学的时候就有接触过编程,所以读大一的时候 C 语言还算是轻车熟路.自然会 ...
- 《编写可维护的javascript》读书笔记(上)
最近在读<编写可维护的javascript>这本书,为了加深记忆,简单做个笔记,同时也让没有读过的同学有一个大概的了解. 一.编程风格 程序是写给人读的,所以一个团队的编程风格要保持一致. ...
- 《编写可维护的JavaScript》之编程实践
最近读完<编写可维护的JavaScript>,让我受益匪浅,它指明了编码过程中,需要注意的方方面面,在团队协作中特别有用,可维护性是一个非常大的话题,这本书是一个不错的起点. 本书虽短,却 ...
- 《编写可维护的javascript》读书笔记(中)——编程实践
上篇读书笔记系列之:<编写可维护的javascript>读书笔记(上) 上篇说的是编程风格,记录的都是最重要的点,不讲废话,写的比较简洁,而本篇将加入一些实例,因为那样比较容易说明问题. ...
- 编写可维护的JavaScript 收纳架
如果你看过Nicolas C.Zakas写过的任何作品,你必须承认他是个不折不扣的天才.也只有天才级的才能写出<JavaScript高级程序设计>让所有的前端攻城师人手一本.Nicolas ...
- 编写可维护的JavaScript之编程风格
在团队中只有每个人的编程风格一致,大家才能方便的互相看懂和维护对方的代码. 1. 层级缩进 对于层级缩进目前有两种主张:1)使用制表符这种方法有两种好处,第一,制表符和缩进层级之间是一一对应关系,符合 ...
- 推荐一本好书:编写可维护的JavaScript(可下载)
目录 推荐一本好书:编写可维护的JavaScript(可下载) 书摘: 下载: 有些建议: 推荐一本好书:编写可维护的JavaScript(可下载) 书摘: 很多设计模式就是为了解决紧耦合的问题.如果 ...
随机推荐
- 【详解】ERP、APS与MES系统是什么?
ERP是什么?MES是什么?APS又是什么?无论他们有什么功能,对企业有什么意义,不过都是计算机在读写一些数据而已.实际上这一切的本质不过是数据在硬盘和内存中快速的读和写. ERP是--,APS是-- ...
- Spark on Yarn:任务提交参数配置
当在YARN上运行Spark作业,每个Spark executor作为一个YARN容器运行.Spark可以使得多个Tasks在同一个容器里面运行. 以下参数配置为例子: spark-submit -- ...
- PostgreSQL Replication之第一章 理解复制概念(1)
PostgreSQL Replication系列翻译自PostgreSQL Replication一书 在本章中,将会介绍不同的复制概念,您会了解哪些类型的复制对哪一种实用场景是最合适的. 在本章的最 ...
- 查看 Apache并发请求数及其TCP连接状态
查看 Apache并发请求数及其TCP连接状态 (2011-06-27 15:08:36) 服务器上的一些统计数据: 1)统计80端口连接数 netstat -nat|grep -i "80 ...
- My family No.1
Ok, in my family, there are seven people including my father, mother, three sisters, one brother and ...
- Tomcat 常用配置及网站部署
一.同一Tomcat 多个端口部署不同的项目 在tomcat 安装目录下C:/Program Files/apache-tomcat-6.0.29/conf找到server.xml (1 ...
- 3.MongoDB下Windows下的安装
由于博主目前使用的是Windows的系统,没有使用Linux等其它的系统,因此此安装配置和开发使用,均是在Windows下进行的,以后在使用其它的系统的时候,再将其它系统的配置的使用补充上来. 1.下 ...
- extjs 学习小窍门
一.从form中获取field的三个方法: 1.Ext.getCmp('id'); 2.FormPanel.getForm().findField('id/name'); 3.Ext.get('id/ ...
- paper 117:image matting 数字抠图
很多公式和图传起来比较麻烦,其实这是一篇论文(仅参考) 图像和视频抠图(Matting)技术可以分成自动和半自动:根据背景的先验知识,又有蓝屏背景,已知背景,和自然背景扣图.报告介绍了自然背景下的半自 ...
- 转载 wpf使用经验
转载自 胡庆访[ http://zgynhqf.cnblogs.com/ ] WPF 是一个界面层框架技术,要对 WPF 技术达到熟练运用的程度,需要同时拥有开发和设计两方面的知识.而我作为一名开发人 ...