js一维数组、多维数组和对象的混合使用方法
这篇文章的主要目的是讲解JavaScript数组和对象的混合使用,由于JS的弱检查特性,因此在JS数组中可以同时存储不同类型的变量,比如你可以把数字、字符串、字符、对象等内容放在同一个数组中。对象也可以做同样的事情,区别是对象可以指定对象里每一个成员的别名,这样在编程的时候数据更易读,比如:
vararr1=["飞鱼",25,172,"江苏"]; varperson={name:"飞鱼",age:25,height:172,province:"江苏"};
这样,person.name是不是比arr1[0]更易读,更易使用?当然数组和对象各有优势,本文的重点是将二者的优势结合起来,综合使用。
一维数组
下面的代码创建名为cars的数组:先创建数组,再一一赋值
varcars=newArray(); cars[0]="Audi"; cars[1]="BMW"; cars[2]="Volvo";
或者(condensedarray):在创建数组对象的时候赋值
varcars=newArray("Audi","BMW","Volvo");
或者(literalarray):不创建变量,直接辅助,不过注意创建对象时用的小括号“()”,而直接赋值时用的是方括号“[]”,这个一不小心就容易出错。
实例
varcars=["Audi","BMW","Volvo"];
上面是一维数组的三种创建方式。由于JS的弱检查性,你可以在一维数组中放不同类型的变量。
二维和多维数组:
1、创建二维数组方法一:先创建一个一维数组,然后该一维数组的所有成员再创建一维数据
varpersons=newArray(); persons[0]=newArray(); persons[1]=newArray(); persons[2]=newArray(); 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、创建二维数组方法二:先创建一个一维数组,然后该一维数组的所有成员直接赋值
varpersons=newArray();
3、创建二维数组方法三:直接赋值
varpersons=[["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、如何返回多维数组的元素个数
如下数组:
varpersons=[["zhangsan",25],["lisi",21],["wangwu",32]];
通过维数(此处是3)乘以每维元素的个数(此处是2)就可以得出该多维数组的元素个数是6了。但是这并不是保险的做法,因为多维数组中每一个维度的元素个数是可以不一样的,如:
varpersons=[["zhangsan",25],["lisi",21,172],["wangwu",32]];
该数组的第一维的第二个元素数组包含三个元素,其他的只有两个,这再使用length来计算还是3,因为第一维的元素个数没变嘛。但是再使用上面的方法计算该多维数组的元素个数就不对了。
因此多维数组的length属性和一维数组一样,永远返回第一维数组的元素个数。计算多维数组的元素个数,可以自己创建一个或多个嵌套for循环来计算,如:
在知道数组的维度的情况下,可以针对该数组写算法,如二维数组:
varpersons=[["zhangsan",25],["lisi",21],["wangwu",32]]; functiongetArr2ElementNum(arr){ vareleNum=0; if(arr==null){ return0; } for(vari=0;i<arr.length;i++){ for(varj=0;j<arr[i].length;j++){ eleNum++; } } returneleNum; } alert(getArr2ElementNum(persons));
在多维数组维度过多,嵌套复杂时,通过上面的方法来写针对的算法就太累了,特别是当这个复杂的多维数组还可能随时变换维度的情况下。如下这个复杂的多重嵌套的多维数组:
vararrN=[["zhangsan",25,[1,"wangyuchu",54,[123,34,16]],43],["lisi",21,172],["wangwu",32,"suzhou"]];
甚至,有些多维嵌套数组比这个还复杂,那怎么计算数组元素个数呢,我写了一个求数组元素个数的函数,不管是一维还多维,也不管是多么复杂的嵌套多维数组,都可以计算出来,算法不麻烦,主要用到了递归的理念:
//判断某个对象是不是数组
functionisArray(obj){ returnobj&&(typeofobj==='object')&&(obj.constructor==Array); } //eleNum变量初始值为0,用来统计数组元素个数 vareleNum=0; //递归计算某个数组元素是不是下一维数组,如果是,则继续递归下去;如果不是,统计元素个数。 functionrecursion(obj){ if(isArray(obj)){ for(varj=0;j<obj.length;j++){ if(!isArray(obj[j])){ eleNum++; continue; } recursion(obj[j]); } }else{ eleNum++; } } //arr为要计算数组元素个数的一维或多维数组,通过调用递归函数recursion返回数组元素个数 functiongetArrNElementNum(arr){ if(arr==null){ return0; } recursion(arr); returneleNum; } //随意定义一个复杂的多维嵌套数组 vararrN=[["zhangsan",25,[1,"wangyuchu",54,[123,34,16]],43],["lisi",21,172],["wangwu",32,"suzhou"]]; //打印出来数组元素个数 alert(getArrNElementNum(arrN));
对象:
对象由花括号分隔。在括号内部,对象的属性以名称和值对的形式(name:value)来定义。属性由逗号分隔:
varperson={firstname:"Bill",lastname:"Gates",id:5566};
上面例子中的对象(person)有三个属性:firstname、lastname以及id。
空格和折行无关紧要。声明可横跨多行:
varperson={ firstname:"Bill", lastname:"Gates", id:5566 };
对象属性有两种寻址方式:
实例
name=person.lastname; name=person["lastname"];
对象和多维数组的混合使用:
想象这么一个场景,要枚举并统计清华大学(qinghua)、北京大学(beida)、浙江大学(zheda)三所大学一共有多少个系,怎么做?
首先,建立一个数组,数组中包括着三所学校:
vardepartments=[qinghua,beida,zheda];
每个学校又有很多不同或相同的学院(xx),如何表示?在这里就要用到数组包含对象了:
vardepartments=[qinghua{xx1,xx2,xx3},beida{xx4,xx5, xx6,xx7},zheda{xx8,xx9}];
每个学院又有不同的系(d),如何表示?
vardepartments=[qinghua{xx1:[d1,d2],xx2[d3,d5], xx3:[d7,d8]},beida{xx4,xx5,xx6,xx7},zheda{xx8, xx9}]; //只是举个例子,后面两个大学我就不表示了
上述例子就是一个数组,该数组的元素是学校对象,学校对象有N个学院属性,而每个学院属性又是一个包含多个系的数组,这就是一个典型的多维数组和对象混合使用的例子,可以简单明了的说明和列表学校、学院和系之间的级别、归属和数量关系。