时间:2021-05-25
每个JavaScript函数都有prototype属性(javascript对象没有这个属性),这个属性引用了一个对象,这个对象就是原型对象。javascript允许我们修改这个原型对象。
修改有2种方式:
方式1:在原有的原型对象上增加属性或者方法
function Person(){}Person.prototype.add = function(){ alert(this.name);};Person.prototype.name = "aty";var p1 = new Person();p1.add();//aty方式2:重写(覆盖)原型对象
function Person(){}Person.prototype = { add : function(){ alert(this.name); }, name : "aty"}var p2 = new Person();p2.add();//aty可以看到上面这2种方式都可以修改原型,那他们的差别究竟是什么呢?到底哪种方式才是推荐的的做法呢?
function Person(){}function Animal(){}var person = new Person();var animal = new Animal();// 修改原型Person.prototype.say = function(){ alert("person");}// 修改原型Animal.prototype = { say : function(){ alert("person"); }}person.say();//personanimal.say();//Uncaught TypeError: undefined is not a function如果是先创建对象,然后再修改原型,那么如果采用方式1,已经创建的对象能够正确访问修改后的原型;如果采用方式2,已经创建的对象无法访问到修改后的原型。从这个角度来看,显然方式1比方式2更好。为什么会这样呢?
function Person(){}function Animal(){}var person = new Person();var animal = new Animal();alert(person.__proto__ === Person.prototype);//truealert(animal.__proto__ === Animal.prototype);//true// 修改原型Person.prototype.say = function(){ alert("person");}// 修改原型Animal.prototype = { say : function(){ alert("person"); }}alert(person.__proto__ === Person.prototype);//truealert(animal.__proto__ === Animal.prototype);//false很显然这与java中"修改引用"和"修改引用指向的对象"很相似,效果也是一样的。
以上这篇关于javascript原型的修改与重写(覆盖)差别详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
接着上文《详解JavaScript基于面向对象之创建对象(1)》继续学习。4、原型方式我们创建的每个函数都有一个通过prototype(原型)属性,这个属性是一
本文实例讲述了JavaScript原型与原型链用法。分享给大家供大家参考,具体如下:一句话说明什么是原型:原型就是一个JavaScript对象,原型能存储我们的
这篇文章主要介绍了JavaScript原型继承和原型链原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
JavaScript中this指向问题记得初学JavaScript时,其中this的指向问题曾让我头疼不已,我还曾私自将其与闭包、原型(原型链)并称JS武林中的
前言在之前的两篇博客中,我们详细探讨了JavaScriptOOP中的各种知识点(JSOOP基础与JS中This指向详解、成员属性、静态属性、原型属性与JS原型链