二维数组

来源:互联网 发布:一件代发怎么传淘宝 编辑:程序博客网 时间:2024/06/10 20:37
方法一:直接定义并且初始化,这种遇到数量少的情况可以用

var _TheArray = [["0-1","0-2"],["1-1","1-2"],["2-1","2-2"]]


方法二:未知长度的二维数组

1
2
3
4
5
6
7
8
9
10
var tArray = new Array(); //先声明一维
for(vark=0;k<i;k++){    //一维长度为i,i为变量,可以根据实际情况改变
 
tArray[k]=newArray();  //声明二维,每一个一维数组里面的一个元素都是一个数组;
 
for(varj=0;j<p;j++){   //一维数组里面每个元素数组可以包含的数量p,p也是一个变量;
 
tArray[k][j]="";   //这里将变量初始化,我这边统一初始化为空,后面在用所需的值覆盖里面的值
 }
}

给定义的数组传入所需的值
tArray[6][1]=5;//这样就可以将5的值传入到数组中,覆盖初始化的空

方法三:在这之前,以上两者方法都有问题,方法二,每次定义都初始化了,虽然后面可以动态修改,但是还是不方法

所以我尝试了一种动态传入值到数组的方法

ps:一些在实践过程中遇到的数组有趣的现象

本来以为二维数组可以像下面这样直接传入值

1
2
3
4
for(vara=0;a<i;a++){
tArray[a]=(matArray[a],addArray[a]);//matArray[a]和addArray[a]是两个数组,这两个数组直接传入tArray[a]中
 
};

结果是tArray[a]中收到的是后面一个数组的值,matArray[a]的内容被忽略的,如果换一个位置,matArray[a]在后面,则传入的是addArray[a]的值。



思考:简单的例子:

代码如下:


var a=[1,2];

var b=[];

b[0]=a;//把数组a作为b数组的元素传入b数组中


上面是最简单的二维数组,上面例子换种写法:

代码如下:
var b=[];

b[0]=[1,2];//把数组[1,2]作为b数组的元素传入b数组中

alert(b[0][1]);  //2
alert(b[0][1]);  //2


可以看出上面的b[0]=[1,2]是可以用的

复制代码 代码如下:

for(var a=0;a<i;a++){

tArray[a]=[ matArray[a],addArray[a] ];  上面例子中的()修改为[] 就可以成功的组成一个二维数组了

};


总结:方法三:代码如下:

for(var a=0;a<i;a++){

tArray[a]=[ aArray[a],bArray[a],cArray[a]]; 还可以增加dArray[a],eArray[a]

};


这种情况适用于已知几个数组,把他们组合成一个二维数组情况

JS 创建多维数组

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<script>
  varallarray=new Array();
  varres="";
  functionloaddata()
  {
   for(vari=0;i<3;i++)
 {
 varstarth=i*200;
 varstrarw=i*200;
 varendh=(i+1)*200;
 varendw=(i+1)*200;
 allarray[i]=newArray();
 allarray[i][0]=newArray();
 allarray[i][1]=newArray();
 allarray[i][0][0]=starth;
 allarray[i][0][1]=strarw;
  allarray[i][1][0]=endh;
 allarray[i][1][1]=endw;
 }
  for(vari=0;i<allarray.length;i++)
  {
    varsh=allarray[i][0][0];
    varsw=allarray[i][0][1]
     vareh=allarray[i][1][0];
    varew=allarray[i][1][1]
    res+="第"+i+"个坐标的开始坐标是:"+sh+","+sw+"结束坐标是:"+eh+","+ew+"<br/>";
  }
  document.getElementById("dv").innerHTML=res;
  }
</script>

原创粉丝点击