前言
数组是一种特殊对象。js中并没有真正的数组,只是用对象模拟数组。
查看对象属性的方法在数组身上也同样适用。值得注意的是:数组的下标类型为字符串,并不是数字。
典型数组和js数组区别
类似c/c++的典型数组特征如下:
- 元素的数据类型相同
- 使用连续的内存存储
- 通过数字下标获取元素
js的数组
- 元素的数据类型可以不同
- 内存不一定是连续的(对象是随机存储的)
- 不能通过数字下标访问,而是通过字符串下标进行访问。(这意味着数组可以有任何key)
上图说明的是最后一点:数组可以有任何key,想证明数组的下标为字符串,用 Object.keys(arr)
创建数组
创建数组有两种方式,分别是:
let arr=[1,2,3] let arr=new Array(1,2,3)
字符串转化为数组 split() Array.from()
可以用这两种方法将字符串转化为字符串数组。
伪数组
没有数组共有属性的数组就是伪数组(伪数组的原型链中并没有数组的原型)
伪数组中并没有push,pop等方法(通过 console.dir(divList)
可看出),我们可以通过 Array.from()
来转化
转化之后就可以成功的push啦
合并两个数组
- concat()
此方法不会改变原数组
let arr1=[1,2,3] let arr2=[4,5,6] arr1.concat(arr2)//[1,2,3,4,5,6] arr1//[1,2,3] arr2//[4,5,6]
截取数组
- slice()
此方法不会改变原数组
let arr=[1,2,3,4,5,6] arr.slice(3) //[4,5,6] arr//[1,2,3,4,5,6]
删数组元素
删头部元素: arr.shift()
arr会被修改,并返回被删元素
let arr=[1,2,3,4,5,6] arr.shift()//1 arr//[2, 3, 4, 5, 6]
删尾部元素: arr.pop()
arr会被修改,并返回被删元素
let arr=[1,2,3,4,5,6] arr.shift()//6 arr//[1, 2, 3, 4, 5]
删中间:
arr.splice(index,1)
//删除index的第一个元素,返回被删元素 arr.splice(index,1,'x')
//在删除位置添加'x' ,返回被删元素 arr.splice(index,1,'x','y')
//在删除位置添加'x'和'y',返回被删元素
let arr=[1,2,3,4,5,6,7,8,9] //删除元素4 arr.splice(3,1)//4 arr//[1, 2, 3, 5, 6, 7, 8, 9] let arr=[1, 2, 3, 5, 6, 7, 8, 9] //删除下标3并添加3.5和4 arr.splice(2,1,3.5,4)//3 arr//[1, 2, 3.5, 4, 6, 7, 8, 9]
查看数组元素
查看属性
- Object.keys(arr)
- Object.values(arr)
let arr=[1,2,3,4,5] arr.x='xxx' Object.keys(arr)//["0", "1", "2", "3", "4", "x"] Object.values(arr)// [1, 2, 3, 4, 5, "xxx"]
for in
循环
查看只含数字的元素
for循环
forEach循环
查看某个元素是否在数组里
arr.indexOf(item)
存在则返回数组索引,否则返回-1
let arr=[1,2,3,4,5,6] arr.indexOf(2)//1 arr.indexOf(7)//0
使用条件查找元素
//查找第一个为偶数的元素 let arr=[1,2,3,4,5,6] arr.find(item=>item%2===0)//2 //查找第一个为偶数的下标 let arr=[1,2,3,4,5,6] arr.findIndex(item=>item%2===0)//1
增加数组中的元素
在尾部添加: arr.push(item1,item2)
let arr=[3,4,5,6] arr.push(7,8,9) arr//[3,4,5,6,7,8,9]
头部添加: arr.unshift(item1,item2)
let arr=[3,4,5,6] arr.unshift(1,2,3) arr//[1, 2, 3, 3, 4, 5, 6]
在中间添加: arr.splice(index,0,'x')
let arr=[1,2,3,4,5,6,7] //在下标为2的位置添加3.33,3.44 arr.splice(2,0,3.33,3.44)//[1, 2, 3.33, 3.44, 3, 4, 5, 6, 7]
总结
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 谭咏麟《20世纪中华歌坛名人百集珍藏版》[WAV+CUE][1G]
- 炉石传说40轮盘术最新卡组代码在哪找 标准40轮盘术卡组代码分享
- 炉石传说亲王贼怎么玩 2024亲王贼最新卡组代码分享
- 炉石传说30.6.2补丁后有什么卡组 30.6.2最强卡组最新推荐
- 模拟之声慢刻CD《蔡琴名曲回顾遇听》[原抓WAV+CUE]
- BruceLiu-WAVES(MusicbySatie)(2024)2CD[24Bit-96kHz]FLAC
- KonstantinKrimmel-MythosSchubertLoewe(2024)[24Bit-96kHz]FLAC
- 2024雷蛇高校挑战赛 嘤式分解助力收官之战
- 海信发布110吋世俱杯官方定制AI电视 引领智能观赛
- 海信发布27英寸显示器大圣G5 Pro:采用自研超解析芯片、友达原厂模组
- 蔡琴《机遇》1:1母盘直刻日本头版[WAV分轨][1.1G]
- 陈百强《与你几分钟的约会》XRCD+SHMCD限量编号版[低速原抓WAV+CUE][994M]
- 陈洁丽《监听王NO.1 》示范级发烧天碟[WAV+分轨][1.1G]
- 单色凌.2014-小岁月太着急【海蝶】【WAV+CUE】
- 陈淑桦.1988-抱紧我HOLD.ME.NOW【EMI百代】【WAV+CUE】