JS创建对象之动态原型模式
2017-05-06 13:30
417 查看
有其他OO主讲经验的开发人员在看到独立的构造函数和原型时,很可能会感到非常困惑。动态原型模式正是致力于解决这个问题的一个方案,它把所有信息都封装在了一个构造函数中,而通过在构造函数中初始化原型(仅在必要的情况下),又保持了同时使用构造函数和原型的优点。换句话说,可以通过检某个应该存在的方法是否有效,来决定是否需要初始化原型。来看一个例子。
注意构造函数代码中加粗的部分,这里只在sayName()方法不存在的情况下,才会将它添加到原型中。这段代码只会在初次调用构造函数时才会执行。此后,原型已经完成初始化,不需要再做什么修改了。不过要记住,这里对原型所有的修改,能够立即在所有实例中得到反映。因此,这种方法确实可以说非常完美,其中,if语句检查的可以是初始化之后应该在任何属性或方法—–不必用一大堆if语句检查每个属性和每个方法;只要检查其中一个即可。对于采用这种模式创建的对象,还可以使用instranceof操作符确定它的类型。
function Person(name, age, job) { //属性 this.name = name; this.age = age; this.job = job; // 方法 if(typeof this.sayName != 'function') { Person.prototyep.sayName = function(){ alert(this.name); } } } var friend = new Person('Nicholas', 29, 'Software Engineer'); friend.sayName();
注意构造函数代码中加粗的部分,这里只在sayName()方法不存在的情况下,才会将它添加到原型中。这段代码只会在初次调用构造函数时才会执行。此后,原型已经完成初始化,不需要再做什么修改了。不过要记住,这里对原型所有的修改,能够立即在所有实例中得到反映。因此,这种方法确实可以说非常完美,其中,if语句检查的可以是初始化之后应该在任何属性或方法—–不必用一大堆if语句检查每个属性和每个方法;只要检查其中一个即可。对于采用这种模式创建的对象,还可以使用instranceof操作符确定它的类型。
使用动态原型模式时,不能使用对象字面量重写原型。前面已经解释过了,如果已经创建了实例的情况下重写原型,那么就会切断与现有实例与新原型之间的联系。
相关文章推荐
- js17---创建对象:构造函数式和原型组合模式、动态原型模式、稳妥构造函数式
- JS中使用动态原型模式、寄生构造函数模式、稳妥构造函数模式创建对象
- JS面向对象的几种创建方式:工厂模式、构造函数模式、原型模式、混合模式、动态原型模式
- js中组合使用构造函数模式和原型模式创建对象
- JS面向对象基础讲解(工厂模式、构造函数模式、原型模式、混合模式、动态原型模式)
- JS面向对象基础讲解(工厂模式、构造函数模式、原型模式、混合模式、动态原型模式)
- javascript创建对象之动态原型模式(五)
- js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式)
- js创建对象的构造函数模式+原型模式和组合继承\Hybrid Pattern & combination inheritance
- js:对象的创建(基于组合和动态原型)
- JS面向对象基础讲解(工厂模式、构造函数模式、原型模式、混合模式、动态原型模式)
- JS中定义对象方式五: 使用动态原型方式创建对象
- js 创建对象的三种方式——工厂模式、构造函数模式、原型模式
- JavaScript之面向对象学习七(动态原型模式、寄生构造函数模式、稳妥构造函数模式创建自定义类型)
- JavaScript高级程序设计之面向对象的程序设计之创建对象之动态原型模式 第6.2.5讲笔记
- 在JS中组合使用构造函数模式和原型模式创建对象
- js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式)
- JS面向对象基础讲解(工厂模式、构造函数模式、原型模式、混合模式、动态原型模式)
- javascript创建对象之动态原型模式(五)
- JavaScript 创建对象---动态原型模式