组合继承的问题是会调用2次超类型构造函数

寄生组合式继承

即通过借用构造函数来继承属性,通过原型链的形式来继承方法,思路:不必为了指定子类型的原型而调用超类型的原型,我们所需要的无非是超类型原型的一个副本而已

function inheritPrototype(subType,superType){

  var prototype=object(subType.prototype);  //创建对象

  prototype.constructor=subType;       //增强对象

  subType.prototype=prototype;        //指定对象

}

第7章 函数表达式

定义函数有两种方式:函数声明和函数表达式

函数声明 function functionName(arg0,arg1,arg2){

    //函数体

}

函数声明提前:执行代码前会先读取函数声明

函数表达式 var functionName=function(arg0,arg1,arg2){

    //函数体

};

由于函数声明提前的存在,最好在函数体内使用函数表达式而非函数声明

递归函数就是一个函数通过名字调用自身的情况下构成的

arguments.callee指向一个正在执行的函数的指针,可以用它来实现对函数的递归调用

闭包是指有权访问另一个函数作用域中的变量的函数

作用域链的概念:当某个函数第一次被调用,会创建一个执行环境及相应的作用域链,并把作用域链赋值给一个特殊的内部属性(即[[Scope]])。然后,使用this、arguments和其它参数的值来初始化函数的活动对象。但在作用域链中,外部的函数活动对象始终处于第二位,以此类推直到作用域链的终点为全局执行环境

作用域链本质上是一个指向变量对象的指针列表,它只引用但不实际包含变量对象

由于闭包会携带包含它的函数的作用域,因此会占用更多内存,需要谨慎使用

闭包的这种配置机制引出了一个问题,即闭包只能取得包含函数中任何变量的最后一个值,我们可以创建另一个匿名函数强制让闭包的行为符合预期

在闭包中使用this可能会导致一些问题,我们知道,this对象在运行时是基于函数的执行环境绑定的:在全局函数中,this等于window,而当函数被作为某个对象的方法调用时,this等于那个对象,匿名函数的执行环境具有全局性,因此其this对象通常指向window

内存泄漏:闭包会引用包含函数的整个活动对象,把变量设置为null,可以解除引用,回收其占用的内存

模仿块级作用域:JavaScript中没有块级作用域规定,只要变量定义在一个函数的活动对象中,就可以在函数内部随处访问它

(function(){

  //这里是块级作用域

}) ();

特权方法:我们把有权访问私有变量和私有函数的公有方法称为特权方法,在函数中定义特权方法有一个缺点,那就是你必须使用构造函数模式来达到这个目的,第6章提到过,构造函数会重复创建一组新方法

静态私有变量:在之前的模拟块级作用域中定义一个全局构造函数(使用函数表达式并不使用var),然后在这个构造函数的原型中定义特权方法,这样所有实例共享一个特权方法,对原型的修改也会反映到所有实例

模块模式
模块模式则是为单例创建私有变量和特权方法,所谓单例就是只有一个实例的对象,声明并赋值一个函数给变量,这个函数里拥有私有变量和函数,return对象字面量(这个字面量对象可以访问到私有变量和私有函数)

简言之,如果必须创建一个对象并以某些数据对其进行初始化,同时还要公开一些能够访问这些私有数据的方法,那么就可以使用模块模式,以这种方式创建的单例都是Object的实例

增强的模块模式

进一步改进了模块模式,在返回对象之前加入对其增强的代码

JavaScript高级程序设计15.pdf的更多相关文章

  1. JavaScript高级程序设计58.pdf

    15章 使用Canvas绘图 略 16章 HTML5脚本编程 HTML5规范了新的HTML标记和JavaScript API,以便简化创建动态Web界面的工作 跨文档消息传递 简称XDM,指来自不同域 ...

  2. JavaScript高级程序设计50.pdf

    hashchange事件 HTML5新增了hashchange事件,以便在URL的参数列表(及URL中“#”号后面的所有字符串)发生变化时通知开发人员,之所以新增这个事件,是因为在Ajax应用中,开发 ...

  3. JavaScript高级程序设计61.pdf

    JSON对象 早期的JSON解析器就是使用JavaScript的eval()函数,ECMAScript5对解析JSON的行为做出了规定,定义了全局对象JSON. JSON对象有2个方法:stringi ...

  4. JavaScript高级程序设计60.pdf

    错误处理 try-catch语句 try{ //可能会导致错误的代码 }catch(error){ //在错误发生时如何处理 } error是一个包含着错误信息的对象,它有一个message属性,保存 ...

  5. JavaScript高级程序设计57.pdf

    表单序列化 首先了解一下浏览器如何将数据发送给服务器 对表单字段的名称和值进行URL编码,使用和号(&)分隔 不发送禁用的表单字段 只发送勾选的复选框和单选按钮 不发送type为“reset” ...

  6. JavaScript高级程序设计55.pdf

    输入模式 HTML5为文本字段新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值 例如,只想在允许在文本字段中输入数值 <input type="text&q ...

  7. JavaScript高级程序设计54.pdf

    过滤输入 对于一些浏览器,可以使用正则表达式里的text()测试用户按下的按键,Firefox和safari(3.1版本之前)会对向上向下.退格键和删除键触发keypress事件,在Firefox中, ...

  8. JavaScript高级程序设计53.pdf

    共有的表单字段方法 每个表单字段都有两个方法:focus()和blur(),其中focus()用于将浏览器焦点设置到表单字段,激活表单字段.可以侦听页面的load事件 EventUtil.addHan ...

  9. JavaScript高级程序设计52.pdf

    表单脚本 表单的基础知识 在HTML中,表单是由<form>元素表示的,在Javascript对应的是HTMLFormElement类型,它继承自HTMLElement,因此具有与其他HT ...

随机推荐

  1. (经典)tcp粘包分析

    转载自csdn:http://blog.csdn.net/zhangxinrun/article/details/6721495 这两天看csdn有一些关于socket粘包,socket缓冲区设置的问 ...

  2. the account is currently locked out. The system administrator can unlock it.

    今天遇到的问题比较有意思.首先是很久没有打开测试数据库了,今天打开,使用service程序测试的时候出现下面的错误提示:Message: System.Data.SqlClient.SqlExcept ...

  3. hadoop_并行写操作思路_2

    如果想实现将 Client端的 File并行写入到 各个Datanode中, 首先, 应该修改的是,DistributedFileSystem中的create方法, 在create 内部调用FSNam ...

  4. Java线程:新特征-线程池

    Sun在Java5中,对Java线程的类库做了大量的扩展,其中线程池就是Java5的新特征之一,除了线程池之外,还有很多多线程相关的内容,为多线程的编程带来了极大便利.为了编写高效稳定可靠的多线程程序 ...

  5. SQL生成一柱双色球

    数据库环境:SQL SERVER 2005 以前用C/JAVA穷举双色球的所有排列,今天想着换成用SQL实现,只生成一柱双色球. 简单说下双色球的规则,双色球由红色球和蓝色球组成,每注投注号码由6个红 ...

  6. 浏览器兼容问题----Firefox不兼容event的解决方法

    一.event.srcElement:当前事件的源: 在IE下,event对象有srcElement属性,但是没有target属性;Firefox下,event对象有target属性,但是没有srcE ...

  7. [Twisted] deferred

    Twisted提供一个优雅的实现(Deferred)来管理回调函数. Deferred Object 的结构 Deferred Object包含两个回调函数列表.一个用来保存成功的回调函数,另一个用来 ...

  8. html-----006

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. jQuery 选择器【1】

    jQuery 选择器 请使用我们的 jQuery 选择器检测器 来演示不同的选择器. 选择器 实例 选取 * $("*") 所有元素 #id $("#lastname&q ...

  10. ACM YTU 1012 u Calculate e

    u Calculate e Problem Description A simple mathematical formula for e is where n is allowed to go to ...