当前位置: 首页 / 技术干货 / 正文
好程序员web前端培训分享JavaScript数据方法汇总

2020-07-29

web前端培训 JavaScript

  好程序员web前端培训分享JavaScript数据方法汇总,在JavaScript中,数组是一个特殊的变量,用于存储不同的元素。它具有一些内置属性和方法,可用于根据需要添加,删除,迭代或操作数。并且了解JavaScript数组方法可以提升你的开发技能。

好程序员

  在本文中,我们将介绍几种关于JavaScript的数组方法,这些方法可以帮助你正确地处理数据。

  1.some()

  2. reduce()

  3. Every()

  4. map()

  5. flat()

  6. filter()

  7. forEach()

  8. findIndex()

  9. find()

  10. sort()

  11. concat()

  12. fill()

  13. includes()

  14. reverse()

  15. flatMap()

  注意,大多数情况下,我们将简化作为参数传递的函数。

  // Instead of using this waymyAwesomeArray.some(test => { if (test === "d") { return test }})// We'll use the shorter onemyAwesomeArray.some(test => test === "d")

  1、some()

  此方法为参数传递的函数测试数组。如果有一个元素与测试元素匹配,则返回true,否则返回false。译者注: some() 不会对空数组进行检测;some() 不会改变原始数组。

  const myAwesomeArray = ["a", "b", "c", "d", "e"]

  myAwesomeArray.some(test => test === "d")

  //-------> Output : true

  2、reduce()

  此方法接收一个函数作为累加器。它为数组中的每个元素依次执行回调函数,不包括数组中被删除或者从未被赋值的元素。函数应用于累加器,数组中的每个值最后只返回一个值。译者注:reduce() 方法接受四个参数:初始值(上一次回调的返回值),当前元素值,当前索引,原数组。

  const myAwesomeArray = [1, 2, 3, 4, 5]

  myAwesomeArray.reduce((total, value) => total * value)

  // 1 * 2 * 3 * 4 * 5

  //-------> Output = 120

  3、Every()

  此方法是对数组中每项运行给定函数,如果数组的每个元素都与测试匹配,则返回true,反之则返回false。

  const myAwesomeArray = ["a", "b", "c", "d", "e"]

  myAwesomeArray.every(test => test === "d")

  // -------> Output : falseconst myAwesomeArray2 = ["a", "a", "a", "a", "a"]

  myAwesomeArray2.every(test => test === "a")

  //-------> Output : true

  4、map()

  该方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。它按照原始数组元素顺序依次处理元素。译者注:map() 不会对空数组进行检测;map() 不会改变原始数组。

  const myAwesomeArray = [5, 4, 3, 2, 1]myAwesomeArray.map(x => x * x)

  //-------> Output : 25

  // 16

  // 9

  // 4

  // 1

  5、flat()

  此方法创建一个新数组,其中包含子数组上的holden元素,并将其平整到新数组中。请注意,此方法只能进行一个级别的深度。

  const myAwesomeArray = [[1, 2], [3, 4], 5]

  myAwesomeArray.flat()

  //-------> Output : [1, 2, 3, 4, 5]

  6、filter()

  该方法接收一个函数作为参数。并返回一个新数组,该数组包含该数组的所有元素,作为参数传递的过滤函数对其返回true。译者注:filter()方法是对数据中的元素进行过滤,也就是说是不能修改原数组中的数据,只能读取原数组中的数据,callback需要返回布尔值;为true的时候,对应的元素留下来;为false的时候,对应的元素过滤掉。

  const myAwesomeArray = [ { id: 1, name: "john" },

  { id: 2, name: "Ali" }, { id: 3, name: "Mass" },

  { id: 4, name: "Mass" },]

  myAwesomeArray.filter(element => element.name === "Mass")

  //-------> Output : 0:{id: 3, name: "Mass"},

  // 1:{id: 4, name: "Mass"}

  7、forEach()

  此方法用于调用数组的每个元素。并将元素传递给回调函数。译者注: forEach() 对于空数组是不会执行回调函数的。

  const myAwesomeArray = [ { id: 1, name: "john" },

  { id: 2, name: "Ali" }, { id: 3, name: "Mass" },]

  myAwesomeArray.forEach(element => console.log(element.name))

  //-------> Output : john

  // Ali

  // Mass

  8、 findIndex()

  此方法返回传入一个测试条件(函数)符合条件的数组diyi个元素位置。它为数组中的每个元素都调用一次函数执行,当数组中的元素在测试条件时返回 true 时, findIndex() 返回符合条件的元素的索引位置,之后的值不会再调用执行函数。如果没有符合条件的元素返回 -1译者注:findIndex() 对于空数组,函数是不会执行的, findIndex() 并没有改变数组的原始值。

  const myAwesomeArray = [ { id: 1, name: "john" },

  { id: 2, name: "Ali" }, { id: 3, name: "Mass" },]myAwesomeArray.findIndex(element => element.id === 3)

  // -------> Output : 2myAwesomeArray.findIndex(element => element.id === 7)

  //-------> Output : -1

  9、 find()

  此方法返回通过测试(函数内判断)的数组的diyi个元素的值。find() 方法为数组中的每个元素都调用一次函数执行:当数组中的元素在测试条件时回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。如果没有符合条件的元素返回 undefined。译者注: find() 对于空数组,函数是不会执行的;find() 并没有改变数组的原始值。

  const myAwesomeArray = [ { id: 1, name: "john" },

  { id: 2, name: "Ali" }, { id: 3, name: "Mass" },] myAwesomeArray.find(element => element.id === 3)

  // -------> Output : {id: 3, name: "Mass"}

  myAwesomeArray.find(element => element.id === 7)

  //-------> Output : undefined

  10、 sort()

  此方法接收一个函数作为参数。它对数组的元素进行排序并返回它。也可以使用含有参数的sort()方法进行排序。

  const myAwesomeArray = [5, 4, 3, 2, 1]

  // Sort from smallest to largestmyAwesomeArray.sort((a, b) => a - b)

  // -------> Output : [1, 2, 3, 4, 5]

  // Sort from largest to smallestmyAwesomeArray.sort((a, b) => b - a)

  //-------> Output : [5, 4, 3, 2, 1]

  11、 concat()

  此方法用于连接两个或多个数组/值,它不会改变现有的数组。而仅仅返回被连接数组的一个新数组。

  const myAwesomeArray = [1, 2, 3, 4, 5]const

  myAwesomeArray2 = [10, 20, 30, 40, 50]

  myAwesomeArray.concat(myAwesomeArray2)

  //-------> Output : [1, 2, 3, 4, 5, 10, 20, 30, 40, 50]

  12、 fill()

  此方法的作用是使用一个固定值来替换数组中的元素。该固定值可以是字母、数字、字符串、数组等等。它还有两个可选参数,表示填充起来的开始位置(默认为0)与结束位置(默认为array.length)。译者注:fill() 方法用于将一个固定值替换数组的元素。

  const myAwesomeArray = [1, 2, 3, 4, 5]

  // The first argument (0) is the value

  // The second argument (1) is the starting index

  // The third argument (3) is the ending indexmyAwesomeArray.fill(0, 1, 3)

  //-------> Output : [1, 0, 0, 4, 5]

  13、 includes()

  此方法用于判断字符串是否包含指定的子字符串。如果找到匹配的字符串则返回 true,否则返回 false。

  译者注:includes() 方法区分大小写。

  const myAwesomeArray = [1, 2, 3, 4, 5]myAwesomeArray.includes(3)

  // -------> Output : truemyAwesomeArray.includes(8)

  // -------> Output : false

  14、 reverse()

  此方法用于颠倒数组中元素的顺序。diyi个元素成为最后一个,最后一个元素将成为diyi个。

  const myAwesomeArray = ["e", "d", "c", "b", "a"]

  myAwesomeArray.reverse()

  // -------> Output : ['a', 'b', 'c', 'd', 'e']

  15、 flatMap()

  该方法将函数应用于数组的每个元素,然后将结果压缩为一个新数组。它在一个函数中结合了flat()和map()。

  const myAwesomeArray = [[1], [2], [3], [4], [5]]

  myAwesomeArray.flatMap(arr => arr * 10)

  //-------> Output : [10, 20, 30, 40, 50]

  // With .flat() and .map()myAwesomeArray.flat().map(arr => arr * 10)

  //-------> Output : [10, 20, 30, 40, 50]

  免责声明:本文图片及文字信息均由小编转载自网络,如有侵权请联系我们进行删除。

好程序员公众号

  • · 剖析行业发展趋势
  • · 汇聚企业项目源码

好程序员开班动态

More+
  • HTML5大前端 <高端班>

    开班时间:2021-04-12(深圳)

    开班盛况

    开班时间:2021-05-17(北京)

    开班盛况
  • 大数据+人工智能 <高端班>

    开班时间:2021-03-22(杭州)

    开班盛况

    开班时间:2021-04-26(北京)

    开班盛况
  • JavaEE分布式开发 <高端班>

    开班时间:2021-05-10(北京)

    开班盛况

    开班时间:2021-02-22(北京)

    开班盛况
  • Python人工智能+数据分析 <高端班>

    开班时间:2021-07-12(北京)

    预约报名

    开班时间:2020-09-21(上海)

    开班盛况
  • 云计算开发 <高端班>

    开班时间:2021-07-12(北京)

    预约报名

    开班时间:2019-07-22(北京)

    开班盛况
IT培训IT培训
在线咨询
IT培训IT培训
试听
IT培训IT培训
入学教程
IT培训IT培训
立即报名
IT培训

Copyright 2011-2023 北京千锋互联科技有限公司 .All Right 京ICP备12003911号-5 京公网安备 11010802035720号