JavaScript原型链

以下代码执行后,a.x 和 b.x 的结果分别是?

function A(x){
    this.x = x;
}
A.prototype.x = 1;

function B(x){
    this.x = x;
}
B.prototype = new A();
var a = new A(2), b = new B(3);
delete b.x;

a不用说,主要看b

function A(x){
    this.x = x;
 }
 A.prototype.x = 1;
 function B(x){
	 this.x = x;
 }
 B.prototype = new A();//#1
 var b = new B(3);//#2
 delete b.x;//#3

#1:创建一个 A 的实例对象赋值给 B.prototype,此时 B.prototype = { x : undefined }
#2:创建一个 B 的实例 b,此时 b = { x : 3 },b.__proto__ = B.prototype = { x : undefined }
#3:删除 b 中的 x,此时 b = { },b.__proto__ = B.prototype = { x : undefined }

ref > MDN继承与原型链

题目来源牛客网

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值