博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript之面向对象学习六原型模式创建对象的问题,组合使用构造函数模式和原型模式创建对象...
阅读量:6457 次
发布时间:2019-06-23

本文共 1602 字,大约阅读时间需要 5 分钟。

一、仔细分析前面的原型模式创建对象的方法,发现原型模式创建对象,也存在一些问题,如下:

1、它省略了为构造函数传递初始化参数这个环节,结果所有实例在默认的情况下都将取得相同的属性值,这还不是最大的问题!

2、最大的问题是原型中的所有属性是被很多实例所共享的,这种共享对于函数非常合适,对于那些包含基本值的属性也说得过去,因为我们知道可以在实例上添加一个同名属性,可以隐藏原型中的对应属性。但是对于包含应用类型值的属性来说,问题就非常严重了,代码如下:

function Person(){}Person.prototype={    constructor:Person,    name:"张三",    age:22,    job:"coder",    friends:["李四","王五"],    sayName:function(){        alert(this.name);    }}var person1=new Person();var person2=new Person();person1.friends.push("赵六");    alert(person1.friends);  //输出:李四,王五,赵六    alert(person2.friends);//输出:李四,王五,赵六

分析上面的代码,当我们为person1添加一个朋友的时候,发现person2同时也被添加了一个朋友,但这并不是我们想要的,而这正是因为原型模式的共享的本性所导致的,只要任何一个实例修改了原型属性对象中的属性值,所有与该原型对象关联的实例都会受到影响!

 

二、组合使用构造函数模式和原型模式

为了解决原型模式不能初始化参数和共享对于引用模式所存在的问题!这里我们可以采用构造函数模式和原型模式的结合模式来创建自定义类型,构造函数用于与解决初始化参数(实例属性的定义),原型模式用于共享  方法和constructor。

这种构造函数与原型组合的模式创建自定义类型,是ECMAScript中使用最广泛、认同度最高的一种创建自定义类型的方法。可以说,这是用来定义引用类型的一种默认模式。

代码如下:

 

function Person(name,age,job){        this.name=name;        this.age=age;        this.job=job;        this.friends=["小超","大超"];    }    Person.prototype={        constructor:Person,        sayName:function(){            alert(this.name);        }    }    var person1=new Person("张三",22,"coder");    var person2=new Person("李四",22,"coder");    person1.friends.push("Stephen Curry","Kevin Durant");    alert(person1.friends); //输出:小超,大超,Stephen Curry,Kevin Durant    alert(person2.friends);//输出:小超,大超

 

通过上面的输出我们发现组合使用构造函数模式和原型模式创建的自定义类型及解决了

1、构造函数:构造函数创建类型相同的函数,确是不同的作用域链和标识符解析(因为在JS中每创建一个函数就是一个对象,所以  (导致了构造函数中的方法)  在不同的实例中都需要重新创建一遍,但是这些方法做的确实同一件事情);

2、原型模式:其不能初始化参数,以及它的共享性对与一些引用类型所造成的影响(比如数组);

 

转载地址:http://bwizo.baihongyu.com/

你可能感兴趣的文章
mysql的数据类型int、bigint、smallint 和 tinyint取值范围
查看>>
利用网易获取所有股票数据
查看>>
移动铁通宽带上网设置教程
查看>>
Python算法(含源代码下载)
查看>>
利用Windows自带的Certutil查看文件MD5
查看>>
通过原生js添加div和css
查看>>
简单的导出表格和将表格下载到桌面上。
查看>>
《ArcGIS Engine+C#实例开发教程》第一讲桌面GIS应用程序框架的建立
查看>>
JAVA - 大数类详解
查看>>
查询指定名称的文件
查看>>
Python 嵌套列表解析
查看>>
[GXOI/GZOI2019]旧词——树链剖分+线段树
查看>>
anroid 广播
查看>>
AJAX POST&跨域 解决方案 - CORS
查看>>
关于最小生成树中的kruskal算法中判断两个点是否在同一个连通分量的方法总结...
查看>>
开篇,博客的申请理由
查看>>
Servlet 技术全总结 (已完成,不定期增加内容)
查看>>
[JSOI2008]星球大战starwar BZOJ1015
查看>>
CountDownLatch与thread-join()的区别
查看>>
linux下MySQL安装登录及操作
查看>>