这周也是拿到了同程的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章总结的更多相关文章

  1. 读《编写可维护的JavaScript》第一章总结

    第一章 基本的格式化 1.4 ① 换行 当一行长度到达了单行最大的字符限制时,就需要手动将一行拆成俩行.通常我们会在运算符后换行,下一行会增加俩个层级的缩进. // 好的做法: 在运算符后换行,第二行 ...

  2. [已读]编写可维护的javascript

    13年4月份出版,作者是大名鼎鼎的Zakas,他的另两本书<javascript高级程序设计>与<高性能javascript>你一定听过或者读过. 这本书重点讲了编码风格和编码 ...

  3. 【读书笔记】读《编写可维护的JavaScript》 - 编程实践(第二部分)

    本书的第二个部分总结了有关编程实践相关的内容,每一个章节都非常不错,捡取了其中5个章节的内容.对大家组织高维护性的代码具有辅导作用. 5个章节如下—— 一.UI层的松耦合 二.避免使用全局变量 三.事 ...

  4. 拯救一切强迫症 - 读《编写可维护的 JavaScript》(一)

    拯救一切强迫症 - 读<编写可维护的 JavaScript>(一) 本文写于 2020 年 4 月 24 日 我在小学的时候就有接触过编程,所以读大一的时候 C 语言还算是轻车熟路.自然会 ...

  5. 《编写可维护的javascript》读书笔记(上)

    最近在读<编写可维护的javascript>这本书,为了加深记忆,简单做个笔记,同时也让没有读过的同学有一个大概的了解. 一.编程风格 程序是写给人读的,所以一个团队的编程风格要保持一致. ...

  6. 《编写可维护的JavaScript》之编程实践

    最近读完<编写可维护的JavaScript>,让我受益匪浅,它指明了编码过程中,需要注意的方方面面,在团队协作中特别有用,可维护性是一个非常大的话题,这本书是一个不错的起点. 本书虽短,却 ...

  7. 《编写可维护的javascript》读书笔记(中)——编程实践

    上篇读书笔记系列之:<编写可维护的javascript>读书笔记(上) 上篇说的是编程风格,记录的都是最重要的点,不讲废话,写的比较简洁,而本篇将加入一些实例,因为那样比较容易说明问题. ...

  8. 编写可维护的JavaScript 收纳架

    如果你看过Nicolas C.Zakas写过的任何作品,你必须承认他是个不折不扣的天才.也只有天才级的才能写出<JavaScript高级程序设计>让所有的前端攻城师人手一本.Nicolas ...

  9. 编写可维护的JavaScript之编程风格

    在团队中只有每个人的编程风格一致,大家才能方便的互相看懂和维护对方的代码. 1. 层级缩进 对于层级缩进目前有两种主张:1)使用制表符这种方法有两种好处,第一,制表符和缩进层级之间是一一对应关系,符合 ...

  10. 推荐一本好书:编写可维护的JavaScript(可下载)

    目录 推荐一本好书:编写可维护的JavaScript(可下载) 书摘: 下载: 有些建议: 推荐一本好书:编写可维护的JavaScript(可下载) 书摘: 很多设计模式就是为了解决紧耦合的问题.如果 ...

随机推荐

  1. RDIFramework.NET -.NET快速信息化系统开发整合框架 【开发实例 EasyUI】之产品管理(WebForm版)

    RDIFramework.NET—.NET快速开发整合框架 [开发实例]之产品管理(WebForm版) 接上篇:RDIFramework.NET (.NET快速信息化系统开发整合框架) [开发实例]之 ...

  2. RDIFramework.NET ━ .NET快速信息化系统开发框架钜献 V3.0 版本强势发布

    继上个版本“RDIFramework.NET V2.9版本”的推出,受到了重多客户的认可与选择,V2.9版本是非常成功与稳定的版本,感谢大家的认可与长期以来的关注与支持.V3.0版本在V2.9版本的基 ...

  3. sql关联表查询结果并插入

    这里涉及三个表,AA,BB,CC,将AA的数据更新到CC表中,将AA中LABEL_ID分别截取字段与BB表中的label_id对应查询到LABEL_NAME作为CC表的一个字段插入,这里分成四段查询 ...

  4. Url通配符映射

    原文:http://www.cnblogs.com/liukemng/p/3726897.ht 1.URL路径映射 1.1.对一个action配置多个URL映射: 我们把上一篇中的HelloWorld ...

  5. 纪勇破解QQ号问题

    试题描述 来到了新学校,才相处不到一个月,jy就对oyjy一见钟情.于是向oyjy问QQ号.当然身为创(实)新(验)一班的同学,oyjy还是要考考jy.她给了纪勇一个加密后的QQ号,让纪勇解密,解密规 ...

  6. 在virtualbox中安装CentOS-7

    当初才接触linux的时候,因为条件限制,只能在虚拟机中安装linux系统使用,由于是小白,爬了好多坑.于是决定写一篇关于在虚拟机中安装linux系统的博客.一是为了巩固自己的知识,二是希望能够对新手 ...

  7. Android 自定义ListView

    本文讲实现一个自定义列表的Android程序,程序将实现一个使用自定义的适配器(Adapter)绑定 数据,通过contextView.setTag绑定数据有按钮的ListView. 系统显示列表(L ...

  8. jq 弹半透明遮罩层

    jquery制作点击按钮弹出遮罩半透明登陆窗口 // )[^>]*$|^#([\w-]+)$/,M=/^.[^:#\[\.,]*$/,ka=/\S/,$= /^(\s|\u00A0)+|(\s| ...

  9. MATLAB绘图

    matlab绘制散点图 clc,clear x=[11.9,11.5,14.5,15.2,15.9,16.3,14.6,12.9,15.8,14.1]; y=[196.84,196.84,197.14 ...

  10. matlab GUI界面编程总结

    去年做了一些关于Matlab GUI的程序,现在又要做相关的东西,回想起来,当时很多经验没有记录下来,现在回顾起来始终觉得不爽,所以从现在开始,一定要勤写记录. 从简单的例子说起吧. 创建Matlab ...