创建对象之原型模式
来源:互联网 发布:进程调度算法代码 编辑:程序博客网 时间:2024/05/19 04:04
1,原型模式创建对象
原型也是一个对象。我们创建的函数都有一个prototype属性,这个属性指向一个对象,这个对象包含有特定函数创建的实例共享的属性和方法。
使用原型对象可以使所有的实例共享属性和方法,而不必再构造函数中初始化属性和方法。
function Person(){ }; Person.prototype.name="qi"; Person.prototype.age=22; Person.prototype.job="cooder"; var person1=new Person(); var person2=new Person(); console.log(person1.name); //qi console.log(person2.name); //qi
上面我们把所有的属性都添加到构造函数的prototype上面,构造函数变成了一个空的函数。实例访问到的属性是共享的。
很容易看到原型模式有不足的地方,结果所有实例在默认情况下都将取得相同的属性值。虽然这会在某种程度上带来一些不方便,但还不是原型的最大问题。
当原型上的属性是一个引用类型的时候,会有意想不到的结果。
function Person(){ }; Person.job=["coder","son","parent"]; var person1=new Person(); var Person2=new Person(); person1.job.push("bigV"); console.log(person1.job); //["coder","son","parent","bigV"] console.log(person2.job); //["coder","son","parent","bigV"]
可以看到我们在person1上修改属性会影响到person2上面的job属性。这显然不是我们想要的。因为person1的job属性和person2的job属性是共享的。
0 0
- 创建对象之原型模式
- JS创建对象之动态原型模式
- 原型模式(对象创建)
- 设计模式之Prototype(原型模式)对象创建型
- 设计模式之对象创建型 — prototype 原型模式
- 创建对象及原型模式
- JavaScript 创建对象---原型模式
- 设计模式学习之--PROTOTYPE(原型)对象创建型模型
- 《JavaScript高级程序设计》创建对象之原型模式
- 设计模式【1】:原型模式【创建对象】
- 创建模式之Prototype(原型)
- 创建模式之Prototype(原型)
- 创建型之原型模式
- Prototype(原型)---对象创建型模式
- JavaScript创建对象 —— 原型模式
- JavaScript 创建对象---动态原型模式
- (创建模式)设计模式之Prototype(原型)
- 创建型模式之原型模式
- [后缀自动机 模板题] SPOJ 8222 Substrings
- 对这一阶段C语言的总结
- 解决df -h 发现/目录100%的问题
- Openjudge NOI题库1.7编程基础之字符串 34:回文子串
- Shiro Quickstart
- 创建对象之原型模式
- 二叉树的镜像(二叉树的对称性)
- [最小循环表示 后缀自动机 模板题] BZOJ 2882 工艺
- 《ES6 标准入门》读书笔记
- 欢迎使用CSDN-markdown编辑器
- C3P0,Dbutils4mysql分页
- J.U.C--locks--ReentrantLock
- 直线的旋转与相交,计算几何(Morley定理,uva 11178)
- Ubuntu下的截图工具