JavaScript中如何定义多维数组?

JavaScript025

JavaScript中如何定义多维数组?,第1张

其实Javascript是不支持多维数组的,在Javascript里面,如果用 var a = new Array(10,3) 将报错,数组里面可以包含对象,所以可以把数组里面的某个元素再声明为数组,例如

var a = new Array()

a[0] = new Array()

a[0][0] = 1

alert(a[0][0])  //弹出 1

声明的时候赋值

var a = new Array([1,2,3], [4,5,6],    [7,8,9])

var b = [[1,2,3], [4,5,6], [7,8,9]]

效果一样,a采用常规实例化,b是隐性声明,结果都是生成一个多维数组

js/json 数组的操作

1、数组的创建

var arrayObj = new

Array() //创建一个数组

var arrayObj = new

Array([size]) //创建一个数组并指定长度,注意不是上限,是长度

var arrayObj = new Array([element0[,

element1[, ...[, elementN]]]]) 创建一个数组并赋值

要说明的是,虽然第二种方法创建数组指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为5,仍然可以将元素存储在规定长度以外的,注意:这时长度会随之改变。

2、数组的元素的访问

var testGetArrValue=arrayObj[1]

//获取数组的元素值

arrayObj[1]= "这是新值"//给数组元素赋予新的值

3、数组元素的添加

arrayObj. push([item1 [item2 [. . .

[itemN ]]]])// 将一个或多个新元素添加到数组结尾,并返回数组新长度

arrayObj.unshift([item1 [item2 [. . .

[itemN ]]]])// 将一个或多个新元素添加到数组开始,数组中的元素自动后移,返回数组新长度

arrayObj.splice(insertPos,0,[item1[,

item2[, . . .

[,itemN]]]])//将一个或多个新元素插入到数组的指定位置,插入位置的元素自动后移,返回""。

4、数组元素的删除

arrayObj.pop()//移除最后一个元素并返回该元素值

arrayObj.shift()

//移除最前一个元素并返回该元素值,数组中元素自动前移

arrayObj.splice(deletePos,deleteCount)

//删除从指定位置deletePos开始的指定数量deleteCount的元素,数组形式返回所移除的元素

5、数组的截取和合并

arrayObj.slice(start, [end])

//以数组的形式返回数组的一部分,注意不包括 end 对应的元素,如果省略 end 将复制 start 之后的所有元素

arrayObj.concat([item1[, item2[, . . .

[,itemN]]]])//将多个数组(也可以是字符串,或者是数组和字符串的混合)连接为一个数组,返回连接好的新的数组

6、数组的拷贝

arrayObj.slice(0)

//返回数组的拷贝数组,注意是一个新的数组,不是指向

arrayObj.concat()

//返回数组的拷贝数组,注意是一个新的数组,不是指向

7、数组元素的排序

arrayObj.reverse()

//反转元素(最前的排到最后、最后的排到最前),返回数组地址

arrayObj.sort()//对数组元素排序,返回数组地址

8、数组元素的字符串化

arrayObj.join(separator)

//返回字符串,这个字符串将数组的每一个元素值连接在一起,中间用 separator 隔开。

toLocaleString 、toString

、valueOf:可以看作是join的特殊用法,不常用.

const arr = [

{ a: 1, b: 2, c: 3, d: 1, e: 1 },

{ a: 1, b: 2, c: 3, d: 1, e: 1 },

{ a: 2, b: 3, c: 4, d: 4, e: 5 },

{ a: 3, b: 4, c: 5, d: 4, e: 5 },

{ a: 3, b: 4, c: 5, d: 4, e: 5 },

]

const arr2 = []

for (let i = 0, j = 0i <arr.lengthi++) {

const a = arr.filter((item, index) =>{

return JSON.stringify(item) === JSON.stringify(arr[i])

})

if (a.length >1) i += a.length - 1

arr2.push(a)

}

console.log(arr2)