理解Javascript對象
這一篇的例子,主要是來引起對Javascript對象的理解及注意的。其實是一種面試時的一個坑,實際項目中也是很少用得到,但是為了提高警惕性,我們來看這個例子:
代碼名稱
var first = {};var second = {k:"second"};var third = {k:"third"};first[second] = 100;first[third] = 200;console.log(first[second])//這里會輸出什么內容呢?
如果要自己做一下這個題,后面的解釋先不看。
這里會輸出什么樣的結果呢?可能大部分人會覺得結果是100,或者是題目有錯誤,再或者是結果是200。
其實最終結果是200。
為什么? 因為second、third都是對象,而且都是[object object],因此first[second] 等價于first[[object object]] 同樣first[third] 等價于first[[object object]] 所以最終的結果可以是first["[object object]"],例子中對這個表達式進行了兩次賦值操作,所以最終的結果是200。
所以在javascript中,很多的細節需要我們去注意的,或許就是那些面試者,不知道出什么面試題,盡出這些陷阱式的題目。不過,我們就是需要把基礎打牢固了,什么都不怕! 后續我會繼續出一些題目來做講解!
通過一個簡簡單單的例題,引發了大家的思考,為大家學習javascript對象提供了有了許多啟發,希望大家有所收獲。
【理解Javascript對象】相關文章:
對javascript的理解08-08
javascript克隆對象深度介紹07-25
理解JavaScript原型鏈教程09-02
JavaScript中的三種對象10-24
javascript的閉包概念怎么理解06-15
關于javascript對象之內置和對象Math的使用方法10-08
淺談javascript中的單線程理解08-16