JavaScript對象---遞歸遍歷對象


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", "班長"]

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM