JavaScript高级程序设计15.pdf
组合继承的问题是会调用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的更多相关文章
- JavaScript高级程序设计58.pdf
15章 使用Canvas绘图 略 16章 HTML5脚本编程 HTML5规范了新的HTML标记和JavaScript API,以便简化创建动态Web界面的工作 跨文档消息传递 简称XDM,指来自不同域 ...
- JavaScript高级程序设计50.pdf
hashchange事件 HTML5新增了hashchange事件,以便在URL的参数列表(及URL中“#”号后面的所有字符串)发生变化时通知开发人员,之所以新增这个事件,是因为在Ajax应用中,开发 ...
- JavaScript高级程序设计61.pdf
JSON对象 早期的JSON解析器就是使用JavaScript的eval()函数,ECMAScript5对解析JSON的行为做出了规定,定义了全局对象JSON. JSON对象有2个方法:stringi ...
- JavaScript高级程序设计60.pdf
错误处理 try-catch语句 try{ //可能会导致错误的代码 }catch(error){ //在错误发生时如何处理 } error是一个包含着错误信息的对象,它有一个message属性,保存 ...
- JavaScript高级程序设计57.pdf
表单序列化 首先了解一下浏览器如何将数据发送给服务器 对表单字段的名称和值进行URL编码,使用和号(&)分隔 不发送禁用的表单字段 只发送勾选的复选框和单选按钮 不发送type为“reset” ...
- JavaScript高级程序设计55.pdf
输入模式 HTML5为文本字段新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值 例如,只想在允许在文本字段中输入数值 <input type="text&q ...
- JavaScript高级程序设计54.pdf
过滤输入 对于一些浏览器,可以使用正则表达式里的text()测试用户按下的按键,Firefox和safari(3.1版本之前)会对向上向下.退格键和删除键触发keypress事件,在Firefox中, ...
- JavaScript高级程序设计53.pdf
共有的表单字段方法 每个表单字段都有两个方法:focus()和blur(),其中focus()用于将浏览器焦点设置到表单字段,激活表单字段.可以侦听页面的load事件 EventUtil.addHan ...
- JavaScript高级程序设计52.pdf
表单脚本 表单的基础知识 在HTML中,表单是由<form>元素表示的,在Javascript对应的是HTMLFormElement类型,它继承自HTMLElement,因此具有与其他HT ...
随机推荐
- javascript类继承系列四(组合继承)
原理: 结合了原型链和对象伪装各自优点的方式,基本思路是:使用原型链继承原型上的属性和方法,使用对象伪装继承实例属性,通过定义原型方法,允许函数复用,并运行每个实例拥有自己的属性 function B ...
- framework 4.5.1安装时发生严重错误
http://jingyan.baidu.com/article/a501d80c0a74b4ec630f5ee5.html http://jingyan.baidu.com/article/d807 ...
- HDU 1074 Doing Homework (dp+状态压缩)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1074 题目大意:学生要完成各科作业, 给出各科老师给出交作业的期限和学生完成该科所需时间, 如果逾期一 ...
- 【BZOJ1875】【矩阵乘法】[SDOI2009]HH去散步
Description HH有个一成不变的习惯,喜欢饭后百步走.所谓百步走,就是散步,就是在一定的时间 内,走过一定的距离. 但是同时HH又是个喜欢变化的人,所以他不会立刻沿着刚刚走来的路走回. 又因 ...
- .net平台下socket异步通讯
1,首先添加两个windows窗体项目,一个作为服务端server,一个作为客户端Client 2,然后添加服务端代码,添加命名空间,界面上添加TextBox控件 using System.Net; ...
- Trac的使用思考
为什么要使用Trac? 这是由于在软件开发当中需要设定阶段性的目标,和进行文档的统一归档,并且便于进行多人协同工作. Trac是基于Python开发的.所以要使用Trac就需要对于Python有一定的 ...
- 《Velocity java开发指南》中文版(上)转载
文章引自:http://sakyone.iteye.com/blog/524289 1.开始入门 Velocity是一基于java语言的模板引擎,使用这个简单.功能强大的开发工具,可以很容易的将数据对 ...
- USACO 2.2 Subset Sums 集合(subset)
Description 对于从1到N的连续整集合,能划分成两个子集合,且保证每个集合的数字和是相等的.举个例子,如果N=3,对于{1,2,3}能划分成两个子集合,他们每个的所有数字和是相等的: {3} ...
- 两个winform窗体同步
/// <summary> /// 初始left距离 /// </summary> int initx = 0; /// ...
- demo_03HTML5中的动画效果
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...