百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>JS教程> javascript基础知识之prototype原型详解
分享文章到:

javascript基础知识之prototype原型详解

发布时间:01/15 来源: 浏览: 关键词:
这篇文章详细的介绍了js中的基础知识prototype原型,给了简单易懂的实例代码,有需要的同学赶快看看吧!

javascript的prototype原型简单介绍:
prototype原型是javascript中特别重要的概念,属于必须要掌握,如果没有良好的掌握的话,进一步用好或者学好js基本是不可能的实现的事情,并且此概念稍有难度,可能对于初次接触的朋友来说有点困难,下面就通过代码实例简单介绍一下prototype原型的用法。

一.基本概念:

每一个函数都具有一个prototype属性。
此属性是一个指针,能够指向一个对象,而此对象将会被由构造函数创建的对象实例所共享,也就是会继承此对象。
总结:prototype所指向的对象是被构造函数所创建的对象实例所共同共享的。
创建的对象实例有一个内部属性[[Prototype]],它是一个指针,指向构造函数原型(prototype)指向的对象。
先看一段代码:

<script>
functionantzone(name,age){
 this.webname=name;
 this.age=age;
}
antzone.prototype.getName=function(){
 returnthis.webname;
}
varoantzone=newantzone("111",10);
console.log(oantzone.getName());
</script>

效果图:

图示如下:

上面图片基本说明了prototype的作用。
二.代码实例:
实例一:

functionantzone(name,age){
 this.webname=name;
 this.age=age;
}
varobj={
 address:"江苏省徐州"
}
varoantzone=newantzone("1",10);
antzone.prototype=obj;
console.log(oantzone.address);

看以上代码,很多朋友可能以为输出值是"江苏省徐州",但是实际输出内容是undefined,这是因为在使用构造函数创建对象oantzone的时候,oantzone对象内部属性[[Prototype]]将会指向antzone()构造函数的原型prototype所指向的对象,而后来antzone.prototype=obj是重置构造函数的原型,而oantzone的内置属性[[Prototype]]指向依然是原来的对象,自然oantzone.address是undefined。
实例二:

<script>
functionantzone(name,age){
 this.webname=name;
 this.age=age;
}
varobj={
 address:"江苏省徐州"
}
antzone.prototype=obj;
varoantzone=newantzone("1",10);
console.log(oantzone.webname+oantzone.address);
</script>

此代码和上一段代码的唯一不同,就是第八行和第九行进行了一下交换,这样就可以输出"江苏省徐州",这个就不难理解了,因为对象实例是在重置原型以后创建的。
实例三:

functionantzone(name,age){
 this.webname=name;
 this.age=age;
}
varobj={
 address:"江苏省徐州"
}
antzone.prototype.add=obj;
varoantzone=newantzone("1",10);
console.log(oantzone.add.address);

以上代码只是修改对象原型,而不是重置对象原型。

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有9人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板