码迷,mamicode.com
首页 > Web开发 > 详细

js prototype

时间:2014-04-28 05:00:54      阅读:545      评论:0      收藏:0      [点我收藏+]

标签:type   cti   new   function   define   prototype   delete   name   efi   js   

prototype 原型。

我们每创建一个函数 都会创建一个 prototype的属性,这个属性指向了这个函数的原型对象。

function A(){}  ,A.prototype  ,prototype原型只能运用在对象上,不能运用在对象的实例上 也就是说

A.prototype 是可以的 var a=new A(),  a.prototype 是不可以的。

所有对象的实例共享原型对象。什么意思如下:

function A(){}

A.prototype.Name="张三";//为原型对象加一个Name的属性。

var a=new A();  alert(a.Name) // 张三

var a1=new A(); alert(a1.Name)//张三

js 执行过程  a.Name 先找 A有没有 Name属性,如果没有就去原型对象里找,

当 A有Name属性的时候就会屏蔽原型对象里的Name 属性(这里是屏蔽不是删除)。

如上:

var a=new A();  a.Name="李四";//这是给对象a添加一个Name属性,并不是修改了原型对象的Name的属性值。

alert(a.Name) //李四

var a1=new A(); alert(a1.Name)//张三

当删除了 a.Name (delete a.Name) 属性,再调用 a.Name 又会去原型对象里找到 “张三”。

在js中对象是区分大小的。如上: a.name //undefine

在实例中 有个_proto_属性就是指向原型对象的,但是这个属性无法显示调用。

 

 

 

 

 

js prototype,布布扣,bubuko.com

js prototype

标签:type   cti   new   function   define   prototype   delete   name   efi   js   

原文地址:http://www.cnblogs.com/startlearn/p/3694913.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!