中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

js一維數組、多維數組和對象的混合使用方法
來源:易賢網 閱讀:1258 次 日期:2016-07-08 15:56:07
溫馨提示:易賢網小編為您整理了“js一維數組、多維數組和對象的混合使用方法”,方便廣大網友查閱!

這篇文章的主要目的是講解JavaScript數組和對象的混合使用,由于JS的弱檢查特性,因此在JS數組中可以同時存儲不同類型的變量,比如你可以把數字、字符串、字符、對象等內容放在同一個數組中。對象也可以做同樣的事情,區別是對象可以指定對象里每一個成員的別名,這樣在編程的時候數據更易讀,比如:

var arr1 = ["飛魚", 25, 172, "江蘇"];

var person = {name:"飛魚",age: 25, height:172,province: "江蘇"};

這樣,person.name是不是比arr1[0]更易讀,更易使用?當然數組和對象各有優勢,本文的重點是將二者的優勢結合起來,綜合使用。

一維數組

下面的代碼創建名為 cars 的數組:先創建數組,再一一賦值

var cars=new Array();

cars[0]="Audi";

cars[1]="BMW";

cars[2]="Volvo";

或者 (condensed array):在創建數組對象的時候賦值

代碼如下:

var cars=new Array("Audi","BMW","Volvo");

或者 (literal array):不創建變量,直接輔助,不過注意創建對象時用的小括號“( )”,而直接賦值時用的是方括號“[ ]”,這個一不小心就容易出錯。

實例

代碼如下:

var cars=["Audi","BMW","Volvo"];

上面是一維數組的三種創建方式。由于JS的弱檢查性,你可以在一維數組中放不同類型的變量。

二維和多維數組:

1、 創建二維數組方法一:先創建一個一維數組,然后該一維數組的所有成員再創建一維數據

var persons = new Array();

persons[0] = new Array();

persons[1] = new Array();

persons[2] = new Array();

persons[0][0] = "zhangsan";

persons[0][1] = 25;

persons[1][0] = "lisi";

persons[1][1] = 22;

persons[2][0] = "wangwu";

persons[2][1] = 32;

persons[0] = ["zhangsan", 25];

persons[1] = ["lisi", 21];

persons[2] = ["wangwu", 32];

相比較上一種方法,這個要簡單易讀多了。

代碼如下:

persons.length = 3

2、創建二維數組方法二:先創建一個一維數組,然后該一維數組的所有成員直接賦值

代碼如下:

var persons = new Array();

3、創建二維數組方法三:直接賦值

代碼如下:

var persons = [["zhangsan", 25], ["lisi", 21], ["wangwu", 32]];

4、總結

第一種和第二種方法雖然麻煩一些,但貴在可以先創建一個空的多維數組,然后在for循環中根據自己的需求進行賦值。第三種方法對于枚舉數據來說就比較簡單易用了。

二維數組的最后一個問題,就是二維數組或多維數組的長度是多少?我們測試一下下面的代碼:

代碼如下:

document.write("persons = " + persons + "<br />persons.length = " + persons.length);

輸出的結果是:

persons = zhangsan,25,lisi,21,wangwu,32

也就是說,多維數組的length屬性返回的是多維數組第一維的長度,而不是多維數組中元素的個數。

5、如何返回多維數組的元素個數

如下數組:

代碼如下:

var persons = [["zhangsan", 25], ["lisi", 21], ["wangwu", 32]];

通過維數(此處是3)乘以每維元素的個數(此處是2)就可以得出該多維數組的元素個數是6了。但是這并不是保險的做法,因為多維數組中每一個維度的元素個數是可以不一樣的,如:

代碼如下:

var persons = [["zhangsan", 25], ["lisi", 21, 172], ["wangwu", 32]];

該數組的第一維的第二個元素數組包含三個元素,其他的只有兩個,這再使用length來計算還是3,因為第一維的元素個數沒變嘛。但是再使用上面的方法計算該多維數組的元素個數就不對了。

因此多維數組的length屬性和一維數組一樣,永遠返回第一維數組的元素個數。計算多維數組的元素個數,可以自己創建一個或多個嵌套for循環來計算,如:

在知道數組的維度的情況下,可以針對該數組寫算法,如二維數組:

var persons = [["zhangsan", 25], ["lisi", 21], ["wangwu", 32]];

function getArr2ElementNum(arr) {

var eleNum = 0;

if (arr == null) {

return 0;

}

for (var i = 0; i < arr.length; i++) {

for (var j = 0; j < arr[i].length; j++) {

eleNum++;

}

}

return eleNum;

}

alert(getArr2ElementNum(persons));

在多維數組維度過多,嵌套復雜時,通過上面的方法來寫針對的算法就太累了,特別是當這個復雜的多維數組還可能隨時變換維度的情況下。如下這個復雜的多重嵌套的多維數組:

var arrN = [["zhangsan", 25, [1, "wangyuchu", 54, [123, 34, 16]], 43], ["lisi", 21, 172], ["wangwu", 32, "suzhou"]];

甚至,有些多維嵌套數組比這個還復雜,那怎么計算數組元素個數呢,我寫了一個求數組元素個數的函數,不管是一維還多維,也不管是多么復雜的嵌套多維數組,都可以計算出來,算法不麻煩,主要用到了遞歸的理念:

//判斷某個對象是不是數組

function isArray(obj) {

return obj && ( typeof obj === 'object') && (obj.constructor == Array);

}

//eleNum變量初始值為0,用來統計數組元素個數

var eleNum = 0;

//遞歸計算某個數組元素是不是下一維數組,如果是,則繼續遞歸下去;如果不是,統計元素個數。

function recursion(obj) {

if (isArray(obj)) {

for (var j = 0; j < obj.length; j++) {

if (!isArray(obj[j])) {

eleNum++;

continue;

}

recursion(obj[j]);

}

} else {

eleNum++;

}

}

//arr為要計算數組元素個數的一維或多維數組,通過調用遞歸函數recursion返回數組元素個數

function getArrNElementNum(arr) {

if (arr == null) {

return 0;

}

recursion(arr);

return eleNum;

}

//隨意定義一個復雜的多維嵌套數組

var arrN = [["zhangsan", 25, [1, "wangyuchu", 54, [123, 34, 16]], 43], ["lisi", 21, 172], ["wangwu", 32, "suzhou"]];

//打印出來數組元素個數

alert(getArrNElementNum(arrN));

對象:

對象由花括號分隔。在括號內部,對象的屬性以名稱和值對的形式 (name : value) 來定義。屬性由逗號分隔:

代碼如下:

var person={firstname:"Bill", lastname:"Gates", id:5566};

上面例子中的對象 (person) 有三個屬性:firstname、lastname 以及 id。

空格和折行無關緊要。聲明可橫跨多行:

var person={

firstname : "Bill",

lastname : "Gates",

id    : 5566

};

對象屬性有兩種尋址方式:

實例

name=person.lastname;

name=person["lastname"];

對象和多維數組的混合使用:

想象這么一個場景,要枚舉并統計清華大學(qinghua)、北京大學(beida)、浙江大學(zheda)三所大學一共有多少個系,怎么做?

首先,建立一個數組,數組中包括著三所學校:

代碼如下:

var departments = [qinghua, beida, zheda];

每個學校又有很多不同或相同的學院(xx),如何表示?在這里就要用到數組包含對象了:

代碼如下:

var departments = [qinghua{xx1, xx2, xx3}, beida{xx4, xx5,

 xx6, xx7}, zheda{xx8, xx9}];

每個學院又有不同的系(d),如何表示?

代碼如下:

var departments = [qinghua{xx1:[d1, d2], xx2[d3, d5],

 xx3:[d7, d8]}, beida{xx4, xx5, xx6, xx7}, zheda{xx8,

 xx9}];

 //只是舉個例子,后面兩個大學我就不表示了

上述例子就是一個數組,該數組的元素是學校對象,學校對象有N個學院屬性,而每個學院屬性又是一個包含多個系的數組,這就是一個典型的多維數組和對象混合使用的例子,可以簡單明了的說明和列表學校、學院和系之間的級別、歸屬和數量關系。

更多信息請查看網絡編程
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
主站蜘蛛池模板: 永德县| 集安市| 乌鲁木齐县| 日喀则市| 凤山县| 福建省| 库尔勒市| 炉霍县| 浦县| 高陵县| 泗阳县| 山东| 福建省| 通渭县| 法库县| 上犹县| 牡丹江市| 罗田县| 韶山市| 东辽县| 黑龙江省| 哈巴河县| 九江县| 齐河县| 荃湾区| 华阴市| 邹平县| 莱西市| 思茅市| 中方县| 无棣县| 台湾省| 新乡市| 吉木萨尔县| 宣化县| 昌乐县| 娄底市| 合山市| 蒙阴县| 托克托县| 增城市|