淺談JavaScript數組簡介
數組簡介
數組(Array) - 數組也是一個對象
它和我們普通對象功能類似,也是用來儲存一些值的
不同的是普通對象是使用字符串作為屬性值的,而數組時使用數字來作為索引操作元素。
索引:從0開始的整數
數組的儲存性能比普通對象要好,在開發(fā)中我們經常使用數組來儲存一些數據
創(chuàng)建數組:
var arr = new Array();
使用 typeof檢查一個數組時,會返回 object

向數組中添加元素
語法: 數組[索引] = 值
讀取數組中的元素
語法: 數組[索引]
如果讀取不存在的索引,它也不會報錯而是返回 undefined
獲取數組的長度
可以使用 length屬性來獲取數組的長度(元素的個數)
語法: 數組.length
對于連續(xù)的數組,使用 length可以獲取到數組的長度(元素的個數)
對于非連續(xù)的數組,使用 length會獲取到數組的最大的索引+1
盡量不要創(chuàng)建非連續(xù)的數組。
修改 length
如果修改的 length小于原長度,則多出來部分會空出來
如果修改的 length小于原長度,則多出的元素會被刪除
向數組最后一個位置添加元素
語法: 數組[數組.length] = 值
arr[arr.length] = 70; arr[arr.length] = 80; arr[arr.length] = 90;
數組字面量
使用數組字面量創(chuàng)建數組
語法:[]
var arr = [] ;
使用字面量創(chuàng)建數組時,可以在創(chuàng)建時就指定數組中的元素
var arr = [1,2,3,4,5];
使用構建函數創(chuàng)建數組時,也可以同時添加元素,將要添加的元素作為構建函數的參數傳遞,元素之間使用,隔開
var arr = new Array(1,2,3,4,5);
注意:
用[]創(chuàng)建一個數組數組中一個元素10
var arr = [10];

使用構建函數創(chuàng)建數組一個參數時,是創(chuàng)建一個長度為10的空數組;
var arr = new Array(10);
console.log(arr);
console.log("arr.length="+arr.length);

數組中可以是任意的數據類型
var arr = ["孫悟空", 1, true, null, undefined]; console.log(arr);

可以是對象
var arr = [{name:"孫悟空"}, {name:"豬八戒"}, {name:"沙悟凈"}];
console.log(arr[0].name);

可以是函數
var arr = [
function () { alert(1) },
function () { alert(2) }];
通過arr[0]()調動函數

二維數組
創(chuàng)建:
使用[]
var arr = [[1,2,3],[4,5,6],[7,8,9]]; //3行3列的二維數組
使用new Array
var a = new Array( new Array(10,20,30), new Array(11,22,33), new Array(45,56,67) )
元素的訪問 數組名[行下標][列下標]
(1)二維數組的轉置:
var a = [
['a','b','c'],
['d','e','f'],
['g','h','i'],
['i','k','I']
]
var str = ''
for(var i=0;i<a.length;i++){
for(var j=0;j<a[i].length;j++){
str += a[i][j]+'\t';
}
str += '\n';
}
console.log("轉置前:\n",str);
var res = []
for(var i=0;i<a[0].length;i++){
res[i] = []
for(var j=0;j<a.length;j++){
res[i][j] = a[j][i];
}
}
console.log("轉置后:",res);

(2)定義一個二維數組,輸出這個數組的每行元素的最大值
var str = ''
for(var i=0;i<a.length;i++){ //外循環(huán):a.length表示二維數組的行數
for(var j=0;j<a[i].length;j++){ //內循環(huán):a[i].length表示i行的元素個數(列數)
str += a[i][j]+'\t'
}
str += '\n'; //在每行的末尾添加換行符
}
console.log(str);
for(var i=0;i<a.length;i++){
var max = a[i][0]
for(var j=1;j<a[i].length;j++){
if(max<a[i][j]){
max = a[i][j];
}
}
console.log("第"+(i+1)+"行的最大值是:"+max)
}

總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!
相關文章
JavaScript 入門·JavaScript 具有全范圍的運算符
JavaScript 入門·JavaScript 具有全范圍的運算符...2007-10-10
JavaScript展開操作符(Spread operator)詳解
在本篇文章里小編給大家整理的是關于JavaScript展開操作符(Spread operator)的詳細介紹以及用法,需要的讀者們參考下。2019-07-07
在JavaScript中處理數組之reverse()方法的使用
這篇文章主要介紹了在JavaScript中處理數組之reverse()方法的使用,是JS入門學習中的基礎知識,需要的朋友可以參考下2015-06-06

