寫js時(shí),碰到一個(gè)奇怪的bug。將變量foo的值賦給變量bar后,改變bar也會(huì)改變foo。
簡單研究過后,這種情況只是在改變object和array時(shí)發(fā)生。
var foo = {key: 'foo'}
var bar = foo // bar => {key: 'foo'}
bar.key = 'bar' // 改變bar這個(gè)對(duì)象
bar // => {key: 'bar'}
foo // => {key: 'bar'} foo竟然也被改變了
// go on
bar = 'change it to a string'
bar // => 'change it to a string'
foo // {key: 'bar'} 這回foo不變
結(jié)論:
js中不同變量存儲(chǔ)的object并沒有在內(nèi)存中存儲(chǔ)多份,而只將變量名(foo,bar)當(dāng)成是對(duì)該對(duì)象的引用。array也能看成object,所以同樣遵循這個(gè)規(guī)則。