js 数组的常用方法

news/2024/9/24 13:21:33/

目录

数组关注是否改变原数组

操作

  会影响原数组

push()

unshift()

splice()

不会影响

concat()

会影响原数组

pop()

shift()

splice()

不会影响

slice()

splice()

indexOf()

includes()

find()

排序

reserve()

sort()

转换

join()

迭代方法

some()

every()

forEach()

filter()

map()


数组关注是否改变原数组

操作

  会影响原数组

  • push()

    • 接收任意数量的参数,将他们添加到数组末尾,放回数组最新长度
  • unshift()

    • 在数组头部添加任意多个值,返回新的数组长度
    • javascript">let arr = ['a', 'b', 'c']
      let len = arr.unshift(1, 0)
      console.log(arr) // ['1', '0', 'a', 'b', 'c']
      console.log(len) // 5
  • splice()

    • 传入三个参数,分别是开始位置,0(要删除的元素数量)、插入的元素,返回空数组
    • javascript">let arr = ['a', 'b', 'c']
      let add = arr.splice(1, 0, 'a', 'b')
      console.log(arr) // ['a', 'a', 'b', 'b', 'c']
      console.log(add) // []

不会影响

  • concat()

    • 创建一个当前数组的副本,再把它的参数添加到副本末尾,返回这个新构建的数组,不会影响原始数组
    • javascript">let arr = ['a', 'b', 'c']
      let add = arr.concat('e', ['f', 'g'])
      console.log(add) // ['a', 'b', 'c', 'e', 'f', 'g']
      console.log(arr) // ['a', 'b', 'c']

会影响原数组

  • pop()
    • 删除数组的最后一项,减少数组的length值,返回被删除的项
  • shift()
    • 用于删除数组的第一项,减少数组的length值,返回被删除项
  • splice()
    • 传入两个参数,开始位置及删除数量,返回包含删除元素
    • javascript">let letters = ['a', 'b', 'c', 'd', 'e']
      let letters1 = letters.splice(1,2) 
      console.log(letters) // ['a', 'd', 'e']
      console.log(letters1) //['b', 'c']

不会影响

  • slice()
    • 用于创建一个包含原有数组一个或者多个元素的新数组,不会改变原始数组
    • javascript">let letters = ['a', 'b', 'c', 'd', 'e']
      let letters1 = nums.slice(1) //['b', 'c', 'd', 'e']
      let letters2 = nms.slice(1,3) //['b', 'c']

splice()

  • 会修改原数组的内容
  • 传入三个参数,分别是开始位置,要删除的数量,要插入的任意多个元素,返回被删除元素的数组,对原数组产生影响
  • javascript">let arr = ['a', 'b', 'c']
    let remove = arr.splice(1,1, 'd', 'f')
    console.log(arr) // ['a', 'd', 'f', 'c']
    console.log(remove) // 'b'

查找元素返回元素坐标或者元素值

  • indexOf()

    • 查找元素在数组中的位置,没找到返回-1
    • javascript">let arr = [1,2,3]
      arr.indexOf(2) == 1
  • includes()

    • 查找的元素在数组中的位置,找到true,没找到false
    • javascript">let arr = ['xx', 'banana', 'hah']
      arr.includes('mm') //false
  • find()

    • 返回第一个匹配的元素
    • javascript">let stus =[{name: 'xx',age: '20'},{name: 'xx1',age: '18'},{name: 'xx2',age: '15'}
      ]
      stus.find((currentValue, index, arr) => {return currentValue.age > 18
      }) //{name: 'xx', age: '20'}

排序

reserve()

  • 改变原数组
  • 将数组反转
  • javascript">let arr = [1, 2, 3]
    let result = arr.reserve()
    console.log(result) // [3, 2, 1]

sort()

  • 改变原数组
  • 接受一个比较函数,用于判断哪个值排在前面
  • javascript">function compare(a, b) {return b - a
    }
    let arr = [1, 2, 3]
    arr.sort(compare)

转换

join()

  • 接收一个参数(字符串分隔符),返回包含所有项的字符串
  • javascript">let arr = [1, 2, 3]
    let result = arr.join('.')
    console.log(result) //1.2.3

迭代方法

some()

  • 对数组的每一项都运行传入的函数,至少有一个元素返回true,这个方法就返回true
  • javascript">let arr = [1, 2, 3]
    let result = arr.reserve()
    console.log(result) // [3, 2, 1]

every()

  • 对数组的每一项都运行传入的函数,所有元素返回true,这个方法就返回true
  • javascript">let arr = [1, 2, 3]
    let result = arr.every((item, index, array) => {return item > 2
    })
    console.log(result) //false

forEach()

  • 对数组中的每一项都运行传入的函数,没有返回值

filter()

  • 对数组中的每一项都运行函数,返回为true会组成数组
  • javascript">let arr = [1, 2, 3]
    let result = arr.filter((item, index, array) => {return item > 1
    })
    console.log(result) // [2, 3]

map()

  • 对数组中每一项都运行函数,返回由每次函数调用的结果组成新数组
  • javascript">let arr = [1, 2, 3]
    let result = arr.map((item, index, array) => {return item*2
    })
    console.log(result) // [2, 4, 6]

http://www.ppmy.cn/news/1432498.html

相关文章

Facebook的区块链应用深度分析

去中心化身份验证的意义 在当今数字化社会中,身份验证的重要性不言而喻。对于Facebook这样的大型社交媒体平台来说,确保用户的身份真实性和数据的安全性是至关重要的。传统的中心化身份验证方式存在一定的安全风险和可信性问题,而去中心化身…

贪心算法练习day.1

理论基础 贪心算法是一种常见的解决优化问题的方法,其基本思想就是在问题的每个决策阶段,都选择当前看起来最优的选择,即贪心地做出局部的最优决策,以此得到全局的最优解,例如在十张面额不同的钞票,让我们…

TypeError: Cannot read properties of undefined (reading ‘tapAsync‘)

项目启动,一直报tabAsync未定义,整个项目中没有找到引用的地方; 最终重新安装webpack4版本 解决问题; npm install webpack4

本地部署Docker容器可视化图形管理工具DockerUI并实现无公网IP远程访问——“cpolar内网穿透”

文章目录 前言1. 安装部署DockerUI2. 安装cpolar内网穿透3. 配置DockerUI公网访问地址4. 公网远程访问DockerUI5. 固定DockerUI公网地址 前言 DockerUI是一个docker容器镜像的可视化图形化管理工具。DockerUI可以用来轻松构建、管理和维护docker环境。它是完全开源且免费的。基…

相机1:如何系相机肩带

开始解锁新领域,多看几个相关视频,大概也就可以掌握一两种系相机肩带的方法,本质就是新知识的学习过程,不可能等着或者期待出来一个完整的教程,一步一步自己去探索,自己去查资料。 目录 总述 第一步&#…

vue 钩子函数

目录 钩子函数概念 生命周期钩子函数 keep-alive 钩子函数 自定义指令的钩子函数 路由导航 / 路由守卫 钩子函数 全局守卫 路由独享守卫 导航守卫 钩子函数概念 在 vue 中可以自动执行的函数叫做钩子函数 生命周期钩子函数 vue 从实例创建到销毁过程中被自动执行的函…

JS-47-Node.js06-fs模块-读写文件

Node.js内置的fs模块就是文件系统模块,负责读写文件。 和所有其它JavaScript模块不同的是,fs模块同时提供了异步和同步的方法。 一、回顾:异步方法VS同步方法 1-1、异步方法 因为JavaScript的单线程模型,执行IO操作时&#xff…

光伏无人机勘探技术应用分析

光伏无人机勘探与传统勘探想必,具有智能化作业、测控精度高、环境适应性强等明显优势;卫星勘探辅助其能更快速甚至实时完成测绘拼图;在进行勘察时,可根据需要自由更换机载设备;自动诗经建模使数据更直观,工…