在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 教程/ HTML/ Array 構造函數
arguments 對象
類型轉換
構造函數
instanceof 操作符
自動分號插入
為什么不要使用 eval
對象使用和屬性
作用域與命名空間
this 的工作原理
typeof 操作符
相等與比較
閉包和引用
數組遍歷與屬性
Array 構造函數
原型
hasOwnProperty 函數
undefined 和 null
函數聲明與表達式
setTimeout 和 setInterval
for in 循環(huán)

Array 構造函數

由于 Array 的構造函數在如何處理參數時有點模棱兩可,因此總是推薦使用數組的字面語法 - [] - 來創(chuàng)建數組。

    [1, 2, 3]; // 結果: [1, 2, 3]
    new Array(1, 2, 3); // 結果: [1, 2, 3]

    [3]; // 結果: [3]
    new Array(3); // 結果: [] 
    new Array('3') // 結果: ['3']

    // 譯者注:因此下面的代碼將會使人很迷惑
    new Array(3, 4, 5); // 結果: [3, 4, 5] 
    new Array(3) // 結果: [],此數組長度為 3

譯者注:這里的模棱兩可指的是數組的兩種構造函數語法

由于只有一個參數傳遞到構造函數中(譯者注:指的是 new Array(3); 這種調用方式),并且這個參數是數字,構造函數會返回一個 length 屬性被設置為此參數的空數組。 需要特別注意的是,此時只有 length 屬性被設置,真正的數組并沒有生成。

譯者注:在 Firebug 中,你會看到 [undefined, undefined, undefined],這其實是不對的。在上一節(jié)有詳細的分析。

    var arr = new Array(3);
    arr[1]; // undefined
    1 in arr; // false, 數組還沒有生成

這種優(yōu)先于設置數組長度屬性的做法只在少數幾種情況下有用,比如需要循環(huán)字符串,可以避免 for 循環(huán)的麻煩。

    new Array(count + 1).join(stringToRepeat);

譯者注: new Array(3).join('#') 將會返回 ##

結論

應該盡量避免使用數組構造函數創(chuàng)建新數組。推薦使用數組的字面語法。它們更加短小和簡潔,因此增加了代碼的可讀性。