亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

一個js繼承問題,想不明白啊

一個js繼承問題,想不明白啊

開滿天機 2019-04-16 16:46:19
兩段小代碼第一段:functionOuter(){this.a=1;}functionInner(){}varouter=newOuter();Inner.prototype=outer;varinner=newInner();inner.a+=1;console.log(inner.a,outer.a);第二段:functionOuter(){this.data={a:1};}functionInner(){}varouter=newOuter();Inner.prototype=outer;varinner=newInner();inner.data.a+=1;console.log(inner.data.a,outer.data.a);請問下為什么兩段代碼運行結果不一樣呢?在第二段代碼中,在inner中修改變量為何會影響到outer?
查看完整描述

2 回答

?
湖上湖

TA貢獻2003條經驗 獲得超2個贊

javascript中的繼承,歸根結底就是對象的賦值引用;
第一段中a只是Number類型,賦值是按按值傳遞的;
第二段中data是Object類型,賦值是按共享傳遞的;
按共享傳遞的可以理解為按安全指針傳遞,安全指針不能去解除引用和改變對象,但可以去修改該對象的屬性值。
運行下面的代碼:
functionOuter(){
this.data={
a:1
};
this.data2={
a:1
};
}
functionInner(){
}
varouter=newOuter();
Inner.prototype=outer;
varinner=newInner();
inner.data.a+=1;//這種情況inner.data===outer.data為true
inner.data2={a:2};//這種情況inner.data2===outer.data2為false
console.log(inner.data===outer.data,inner.data.a,outer.data.a);
console.log(inner.data2===outer.data2,inner.data2,outer.data2);
不知道你能不能理解,具體可以看下javascript的賦值策略
                            
查看完整回答
反對 回復 2019-04-16
  • 2 回答
  • 0 關注
  • 319 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號