最新公告
  • 欢迎您光临网站无忧模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • js数组使用总结

    正文概述 掘金(抓泥鳅)   2021-01-17   390

    数组是一种特殊对象。js中并没有真正的数组,只是用对象模拟数组。 js数组使用总结
    查看对象属性的方法在数组身上也同样适用。值得注意的是:数组的下标类型为字符串,并不是数字。
    典型数组和js数组区别
    类似c/c++的典型数组特征如下:

    • 元素的数据类型相同
    • 使用连续的内存存储
    • 通过数字下标获取元素

    js的数组

    • 元素的数据类型可以不同
    • 内存不一定是连续的(对象是随机存储的)
    • 不能通过数字下标访问,而是通过字符串下标进行访问。(这意味着数组可以有任何key)

    js数组使用总结
    上图说明的是最后一点:数组可以有任何key,想证明数组的下标为字符串,用Object.keys(arr)

    创建数组

    创建数组有两种方式,分别是:

      let arr=[1,2,3]
      let arr=new Array(1,2,3)
    

    字符串转化为数组

    • split()
    • Array.from()

    js数组使用总结
    可以用这两种方法将字符串转化为字符串数组。

    伪数组

    没有数组共有属性的数组就是伪数组(伪数组的原型链中并没有数组的原型)

    js数组使用总结 伪数组中并没有push,pop等方法(通过console.dir(divList)可看出),我们可以通过Array.from()来转化
    js数组使用总结
    转化之后就可以成功的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循环

    js数组使用总结

    查看只含数字的元素

    • for循环

    js数组使用总结

    • forEach循环

    js数组使用总结

    查看某个元素是否在数组里

    • 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]
    

    下载网 » js数组使用总结

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元