js的原型

1、Object.getPrototypeOf(person1)==Person.prototype    //true

Object.getPrototypeOf(person1).name    //Person.prototype.name

(其中,person1是Person的一个实例) 

原型中所保存的属性和方法是多个对象实例共享的。

Person.prototype 和 person1的prototype属性都指向Person.prototype;Person.prototype的constructor属性,指向Person,constructor属性也是Person的实例们共享的,所以person1.constructor是Person

2、原型链:当代码要读取一个属性的时候,会执行一个搜索。先从对象实力本身开始,如果没有找到,接下来找指针指向的原型对象。(person1——》Person.prototype)

在实例上添加属性会屏蔽原型上的属性,可以用delete方法删除实例属性,就又可以访问到原型中的属性了。hasOwnProperty()方法可以检测属性是否存在于实例中。

注:读取属性时,可以用Object.getOwnPropertyDescriptor()方法来读取实例中的属性,如果想去的原型属性的描述符,必须直接在原型对象上调用。

3、原型与in操作符:

单独使用in时:alert('name' in person1) //返回布尔值,如果person1.name可以访问到(不论是在实例中还是在原型中)。可以配合person1.hasOwnProperty('name')来确定该属性是存在对象中还是存在原型中;

for-in循环时:循环到的是能够通过对象访问的、可枚举的属性,包括实例中的,也包括原型中的,比如一个属性在原型中是不可枚举的,但是在实例中又重新定义了,这个实例属性也会被枚举(但是这一点在ie8中就不会被枚举)。

要取得对象上所有可枚举的实例属性,可以用Object.keys(person1)方法,返回一个数组,包括了传入对象自己这一层的所有可枚举的属性。

Object.getOwnPropertyNames()方法可以得到所有实例属性,无论是否可枚举。

 4、其实,用到原型的时候可以直接用一个对象赋值给Person.prototype,但是此时Person.prototype中的constructor不再指向Person,所以实例person1.constructor也不再是Person而是Object。虽然prototype找不到了,但是instanceof还可以找到从哪来的。不过也可以在Person.prototype赋值的时候加一条constructor:Person,这样就还可以找到了,但是这种情况下的constructor就是可枚举的,原生的constructor是不可枚举的,如果再想跟默认的一模一样的,可以再用Object.defineProperty()方法把constructor的enumerable设置为false。

5、当一个构造函数新建一个实例之后,再改变prototype里的属性,实例都可以继承,因为是指针指向的;但是如果此时重写prototype(把一个对象赋值给prototype) 实例还是会指向之前的prototype(不离不弃微笑


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值