javascript代码实例教程-js:深入prototype(下:原型重写)

发布时间:2019-02-03 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了javascript代码实例教程-js:深入prototype(下:原型重写)脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

//当属性和方法特别多时,编写起来不是很方便,可以通过json的格式来编写
//由于原型重写,而且没有通过PErson.PRototype来指定,此时的constructor不会再指向Person而是指向Object
//如果constructor真的比较重要,可以在json中说明原型的指向
function Person(){

}

Person.prototype = {
//constructor:Person, //手动指定constructor
name:"octopus",
age:23,
say:function(){
alert(this.name+":"+this.age);
}
}
VAR p1 = new Person();
p1.say(); //octopus:23
alert(p1.constructor==Person); //false

Person.prototype.sayHi(){
alert(this.name+":hi");
}
p1.sayHi(); //octopus:hi

javascript代码实例教程-js:深入prototype(下:原型重写)

//但是如果把原型重写放到new Person()之后,p1.sayHi(); //undefined:hi
function Person(){

}

var p1 = new Person();

Person.prototype.sayHi(){
alert(this.name+":hi");
}
p1.sayHi(); //undefined:hi

Person.prototype = {
//constructor:Person, //手动指定constructor
name:"octopus",
age:23,
say:function(){
alert(this.name+":"+this.age);
}
}
p1.sayHi(); //undefined:hi 有sayHi(),但没有name

javascript代码实例教程-js:深入prototype(下:原型重写)

var p2 = new Person();
p2.sayHi(); //报错:sayHi is not a function 这是因为 p2没有sayHi

javascript代码实例教程-js:深入prototype(下:原型重写)

原创文章转载,请注明出处,本文首发于csdn网站:https://blog.csdn.net/magneto7/article/details/24922481

觉得可用,就经常来吧! 脚本宝典 欢迎评论哦! js脚本,巧夺天工,精雕玉琢。小宝典献丑了!

脚本宝典总结

以上是脚本宝典为你收集整理的javascript代码实例教程-js:深入prototype(下:原型重写)全部内容,希望文章能够帮你解决javascript代码实例教程-js:深入prototype(下:原型重写)所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。