JavaScript 中的所有事物都是對象:字符串、數值、數組、函數...
此外,JavaScript 允許自定義對象。
JavaScript 對象
JavaScript 提供多個內建對象,比如 String、Date、Array 等等。
對象只是帶有屬性和方法的特殊數據類型。
在 ECMAScript 中,不能訪問對象的物理表示,只能訪問對象的引用。每次創建對象,存儲在變量中的都是該對象的引用,而不是對象本身。
本地對象
ECMA-262 把本地對象(native object)定義為“獨立於宿主環境的 ECMAScript 實現提供的對象”。簡單來說,本地對象就是 ECMA-262 定義的類(引用類型)。它們包括:
- Object
- Function
- Array
- String
- Boolean
- Number
- Date
- RegExp
- Error
- EvalError
- RangeError
- ReferenceError
- SyntaxError
- TypeError
- URIError
內置對象
ECMA-262 把內置對象(built-in object)定義為“由 ECMAScript 實現提供的、獨立於宿主環境的所有對象,在 ECMAScript 程序開始執行時出現”。這意味着開發者不必明確實例化內置對象,它已被實例化了。ECMA-262 只定義了兩個內置對象,即 Global 和 Math (它們也是本地對象,根據定義,每個內置對象都是本地對象)。
宿主對象
所有非本地對象都是宿主對象(host object),即由 ECMAScript 實現的宿主環境提供的對象。
所有 BOM 和 DOM 對象都是宿主對象。
var obj = { a:{ name : "maoguotao", age : 18, sex : 'M', }, b:{ name : "maoshuqin", age : 18, sex : 'M', }, c:{ name : "MGT360124", age : 18, sex : 'M', title : { job:"班長" } } }; //遞歸遍歷對象 var arr = []; function f( obj ) { for( var i in obj ) { if ( typeof obj[i] === "object" ) { f ( obj[i] ); }else{ arr.push( obj[i] ); } } } f( obj ); console.log(arr);//["maoguotao", 18, "M", "maoshuqin", 18, "M", "MGT360124", 18, "M", "班長"]