介绍

原型模式(prototype)是指用原型实例指向创建对象的种类,并且通过拷贝这些原型创建新的对象。

正文

对于原型模式,我们可以利用JavaScript特有的原型继承特性去创建对象的方式,也就是创建的一个对象作为另外一个对象的prototype属性值。原型对象本身就是有效地利用了每个构造器创建的对象,例如,如果一个构造函数的原型包含了一个name属性(见后面的例子),那通过这个构造函数创建的对象都会有这个属性。

在现有的文献里查看原型模式的定义,没有针对JavaScript的,你可能发现很多讲解的都是关于类的,但是现实情况是基于原型继承的JavaScript完全避免了类(class)的概念。我们只是简单从现有的对象进行拷贝来创建对象。

真正的原型继承是作为最新版的ECMAScript5标准提出的,使用Object.create方法来创建这样的对象,该方法创建指定的对象,其对象的prototype有指定的对象(也就是该方法传进的第一个参数对象),也可以包含其他可选的指定属性。例如Object.create(prototype, optionalDescriptorObjects),下面的例子里也可以看到这个用法:

// 因为不是构造函数,所以不用大写
var someCar = {
drive: function () { },
name: '马自达 3'
}; // 使用Object.create创建一个新车x
var anotherCar = Object.create(someCar);
anotherCar.name = '丰田佳美'; Object.create运行你直接从其它对象继承过来,使用该方法的第二个参数,你可以初始化额外的其它属性。例如: var vehicle = {
getModel: function () {
console.log('车辆的模具是:' + this.model);
}
}; var car = Object.create(vehicle, {
'id': {
value: MY_GLOBAL.nextId(),
enumerable: true // 默认writable:false, configurable:false
},
'model': {
value: '福特',
enumerable: true
}
}); 这里,可以在Object.create的第二个参数里使用对象字面量传入要初始化的额外属性,其语法与Object.defineProperties或Object.defineProperty方法类型。它允许您设定属性的特性,例如enumerable, writable 或 configurable。 如果你希望自己去实现原型模式,而不直接使用Object.create 。你可以使用像下面这样的代码为上面的例子来实现: var vehiclePrototype = {
init: function (carModel) {
this.model = carModel;
},
getModel: function () {
console.log('车辆模具是:' + this.model);
}
}; function vehicle(model) {
function F() { };
F.prototype = vehiclePrototype; var f = new F(); f.init(model);
return f;
} var car = vehicle('福特Escort');
car.getModel(); 总结 原型模式在JavaScript里的使用简直是无处不在,其它很多模式有很多也是基于prototype的,就不多说了,这里大家要注意的依然是浅拷贝和深拷贝的问题,免得出现引用问题。 同步与推荐 本文已同步至目录索引:深入理解JavaScript系列 深入理解JavaScript系列文章,包括了原创,翻译,转载等各类型的文章,如果对你有用,请推荐支持一把,给大叔写作的动力。

最新文章

  1. C# uploadify 上传 -220 IO Error 问题
  2. 什么是CGI
  3. 我所常用的ajax调用格式
  4. node 日志管理log4js
  5. 分享9款用HTML5/CSS3制作的动物人物动画
  6. delphi xe5 android 开发实现手机打电话和发短信
  7. NSURLConnection请求时间
  8. linux文件系统结构和权限
  9. linux 网络Socket实战
  10. 提高xshell使用效率
  11. QT 4.7支持中文(QT4.7)(中文)(makeqpf)
  12. sqlserver 分页sql语句
  13. tomcat 组件研究一--启动过程总结
  14. 201521123118《java程序与设计》第6周学习总结
  15. 【编程技巧】EXTJS中Ext.grid.GridPanel配置项autoExpandColumn的使用方法
  16. 用icas下载文件报错
  17. Easyui Datagrid 修改显示行号列宽度
  18. 末学者笔记--shell编程上 1 玄
  19. 【keepalived】CentOS7.0下安装教程
  20. Java中锁分类

热门文章

  1. Notes on view-dependent Catmull-Clark subdivision surfaces
  2. OO 面向对象的概念
  3. 求解任意图的最小支配集(Minimun Dominating Set)
  4. bzoj 2780: [Spoj]8093 Sevenk Love Oimaster(广义SAM)
  5. sed--行编辑器命令
  6. UITextView笔记
  7. 省选后CTS/APIO前文化课划水记
  8. JAVA输入随笔
  9. Smarty带来的神秘的数字1
  10. spider_keeper定时任务