再说prototype

直接看代码吧:

//写法一
function A(){}

var s = new A();

A.prototype.title = "123";

alert(s.title);//"123"


//写法二
function A(){}

var s = new A();

A.prototype = {
    title : "123"
};

alert(s.title);//undefined


//写法三
function A(){}

A.prototype.title = "123";

var s = new A();

A.prototype.title = "321";

alert(s.title);//"321"

//写法四
function A(){}

A.prototype = {title:"123"};

var s = new A();

A.prototype = {title:"321"};

alert(s.title);//"123"

 说明什么问题?

我的理解是在调用new操作符时,实例化的对象的__proto__是指向构造函数的prototype当前指向的对象,也就是说下一次实例化之前如果改变构造函数的prototype指向,那么下次实例化出来的对象的__proto__的指向也会跟随构造函数的prototype指向一同改变。有点像C语言里的指针传指针。如下图所示:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值