淺談Javascript數組(推薦),淺談javascript

來源:互聯網
上載者:User

淺談Javascript數組(推薦),淺談javascript

在程式語言中數組的重要性不言而喻,JavaScript中數組也是最常使用的對象之一,數組是值的有序集合,由於弱類型的原因,JavaScript中數組十分靈活、強大,不像是Java等強型別進階語言數組只能存放同一類型或其子類型元素,JavaScript在同一個數組中可以存放多種類型的元素,而且是長度也是可以動態調整的,可以隨著資料增加或減少自動對數組長度做更改。

首先,大概說說數組的基本用法。

   數組,即Array類型,是開發中最常用的類型之一,javascript中的數組和其他語言最大的區別就是每一項可以儲存任何類型的資料,而且數組的大小是可以動態調整的,有點繞?看看代碼吧

   1.數組的建立:

var arr=new Array(20);var arr1=["小傘",1,true,undefined,[2,"王"],""] 

第一行用數組構造法建立了一個length值為20的數組,第二行用數組字面量標記法建立了一個多種資料類型並存的數組。

第一行的方法有點小坑,括弧裡指定的是數組的長度,而不是數組第一個元素是20 ,要想建立有一個元素是20的這麼一個數組,還是用字面量法建立吧。

還有一個小坑,看代碼

var arr=[1,2,];var arr1=[,,,,,]

第一行這句會在IE8以及之前版本中建立一個值分別為1,2,undefined的數組,其他瀏覽器會產生一個兩項分別是1,2的數組

第二行同樣的可能會在不同瀏覽器上包含5項或者6項。(IE9以上修複了這個問題,但還是不推薦這種寫法)

  2.數組元素的基本操作

js的數組非常的靈活,擁有很多數組元素操作的方法,但也有一些小坑,比如:

var arr=[];arr[0]=1;arr[1]=2;arr.push(3); //arr=[1,2,3]arr[arr.length]=4; //arr=[1,2,3,4]arr.unshift(0); //arr=[0,1,2,3,4];delect arr[2]; //arr=[0,1,undefined,3,4]arr[0]=undefined //arr=[undefined,1,undefined,3,4]

push()方法會給數組最後邊添加一個元素,得到的值可以看注釋,^_^

也可以直接手動在數組下標拓展以為,如第三行,其實就相當於push(4);
那如果想在數組元素最前邊添加呢,別急,有unshift()方法。

與此對應的有刪除元素的pop()方法和shift()方法,分別和push(),unshift()對應,就不再贅述了。

delect 運算子對數組的操作不會刪除掉數組的元素,可以說是用undefined來佔個位子,和直接賦值是一樣的。

   3.稀疏數組

稀疏數組是指數組的下標並不是從0開始,一般數組的長度要比元素的個數要多:

var arr1=[undefined];var arr2=new Array(1);0 in arr1; //true0 in arr2; //falsevar arr3=new Array(100);arr3[99]="賦值";99 in arr3; //true98 in arr3; //false

arr1中是因為數組第1列是有值的,雖然是undefined,arr2隻是指定了數組長度,第1列還是沒有值,所以用in語句會返回false。arr3中給第第100個元素賦值後檢測是有值的,對其他列的key是沒有影響的,所以還是返回了false。

以上所述是小編給大家介紹的Javascript數組的相關知識,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對幫客之家網站的支援!

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.