JS新手入门数组处理的实用方法汇总


Posted in Javascript onApril 07, 2021

join()方法:将数组中所有元素通过指定分隔符连接成一个字符串

举例:

myArr.join('-') // 用'-'符号拼接

concat()方法:将两个数组或多个数组合并成一个数组

举例:

myArr.concat(arr1, arr2, ..., arrN)

注意:该方法不会改变现有的数组,所以可以和空数组合并实现复制旧数组,在操作新数组数据时不污染旧数组数据

sort() 方法:用于对数组的元素进行排序

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较

举例:

myArr.sort() // 按字母排序
myArr.sort(function(a, b) {
	return a - b
}) // 按数字升序,降序为b - a
// 箭头函数写法
myArr.sort((a, b) => a - b)

reverse() 方法:用于颠倒数组中元素的顺序

举例:

myArr.reverse()

push() / unshift()方法:向数组的末尾 / 开头添加一个或多个元素,并返回新的长度

举例:

myArr.push(item1, item2, ..., itemN)
myArr.unshift(item1, item2, ..., itemN)

shift()方法:删除数组的第一个元素,并返回第一个元素的值

举例:

myArr.shift()

pop()方法:删除数组的一个元素(默认最后一个元素),并且返回该元素的值

举例:

myArr.pop() // 删除数组最后一个元素
myArr.pop(1) // 删除数组中索引为1的元素

splice()方法:向/从数组中添加/删除项目,然后返回被删除的项目

myArr.splice(index, count, item1, item2, ..., itemN)
// index 必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置
// count 必需。要删除的项目数量。如果设置为 0,则不会删除项目
// item1, item2, ..., itemN 可选。向数组添加的新项目

forEach()方法:方法用于调用数组的每个元素,并将元素传递给回调函数(相当于for循环)

举例:

myArr.forEach(function (item, index, arr) {
 if (index === 3) {
 item = 123
 } 
}) // 循环数组,将索引为3的元素值更改为123
// 箭头函数写法
myArr.forEach((v, i, arr) => if (i === 3) { v = 123 })

注意:以下方法均不会对空数组进行检测,不会改变原始数组

indexOf()方法:查找数组是否存在某个元素,返回下标,没有则返回-1

举例:

myArr.indexOf(item)

注意:indexOf() 方法对大小写敏感!

slice()方法:可提取字符串的某个部分,并以新的字符串返回被提取的部分(浅拷贝数组的元素)

举例:

const newArr = myArr.slice(0, 1)
// 截取数组myArr索引从0到1的部分元素
// 参数:
// begin(可选): 索引数值,接受负值,从该索引处开始提取原数组中的元素,默认值为0。
// end(可选):索引数值(不包括),接受负值,在该索引处前结束提取原数组元素,默认值为数组末尾(包括最后一个元素)

every()方法:用于检测数组中的元素是否满足指定条件(函数提供)(如某个值是否都为true)

如果有一个元素不满足,则整个表达式返回 false,且停止检测;如果所有元素都满足条件,则返回 true

举例:

const state = myArr.every(function (item, index, arr) {
 return item > 10
}) // 检测数组myArr的所有元素是否都大于10,返回一个布尔值state
// 箭头函数写法
const state = myArr.every((v, i, arr) => v > 10)

some()方法:用于检测数组中的元素是否满足指定条件(函数提供)(如某个值是否都为true)

如果有一个元素满足,则整个表达式返回 true ,且停止检测;如果没有满足条件的元素,则返回false

举例:

const state = myArr.some(function (item, index, arr) {
 return item > 10
}) // 检测数组myArr中是否存在元素大于10,返回一个布尔值state
// 箭头函数写法
const state = myArr.some((v, i, arr) => v > 10)

includes()方法:用于判断数组是否包含指定的值,如果找到匹配的值则返回 true,否则返回 false

注意:includes() 方法区分大小写

参数:
searchvalue:必需,要查找的值

start:可选,设置从那个位置开始查找,默认为 0

举例:

const state = myArr.includes(3) // 检测数组myArr中是否存在元素3,返回一个布尔值state
const state = myArr.includes(3, 3) // 从索引3开始检测数组myArr中是否存在元素3,返回一个布尔值state

filter()方法:创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素

举例:

const newArr = myArr.filter(function (item, index, arr) {
 return item > 10
}) // 检测数组myArr中所有元素都大于10的元素,返回一个新数组newArr
// 箭头函数写法
const newArr = myArr.filter((v, i, arr) => v > 10)

map()方法:返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值

map()方法按照原始数组元素顺序依次处理元素

举例:

const newArr = myArr.map(function (item, index, arr) {
 return item * 10
}) // 数组myArr中所有元素都乘于10,返回一个新数组newArr
// 箭头函数写法
const newArr = myArr.map((v, i, arr) => v * 10)

举例(用于数组嵌套对象的类型):

const newArr = myArr.map(function (item, index, arr) {
 return {
 id: item.id,
 newItem: '123'
 }
}) // 处理数组myArr中指定的对象元素里面的元素或新元素,返回一个新数组newArr
// 箭头函数写法
const newArr = myArr.map((v, i, arr) => {
 return {
 id: v.id,
 newItem: '123'
 }
})

find() / findIndex()方法:返回通过测试(函数内判断)的数组的第一个元素的 值 / 索引。如果没有符合条件的元素返回 undefined / -1

举例:

const val = myArr.find(function (item, index, arr) {
 return item > 10
}) // 返回数组myArr中第一个大于10的元素的值val,没有则返回undefined

const val = myArr.findIndex(function (item, index, arr) {
 return item > 10
}) // 返回数组myArr中第一个大于10的元素索引,没有则返回-1

reduce()方法:返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值

这个方法接收两个参数:要执行的函数,传递给函数的初始值

要执行的函数(total, currentValue, currentValue, arr):

total:必选,初始值, 或者计算结束后的返回值

currentValue:必选,当前元素;

currentValue:可选,当前元素索引;

arr:可选,当前元素所属的数组对象

举例1:

const myArr = [1, 2, 3]
const sum = myArr.reduce(function(pre, cur, index, arr) {
 console.log(pre, cur)
 return pre + cur
})
console.log(sum)
// 输出值分别为
// 1, 2
// 3, 3
// 6

举例2(设置初始迭代值):

const myArr = [1, 2, 3]
const sum = myArr.reduce(function(pre, cur, index, arr) {
 console.log(pre, cur)
 return prev + cur
}, 2)
console.log(sum)
// 输出值分别为
// 2, 1
// 3, 2
// 5, 3
// 8

应用:

1.求和、求乘积

const myArr = [1, 2, 3, 4]
const result1 = myArr.reduce(function(pre, cur) {
 return pre + cur
})
const result2 = myArr.reduce(function(pre, cur) {
 return pre * cur
})
console.log(result1) // 6
console.log(result2) // 24

2.计算数组中每个元素出现的次数

const myArr = ['liang','qi','qi','liang','ge','liang'] 
const arrResult = myArr.reduce((pre,cur) =>{
 if(cur in pre){
  pre[cur]++
 }else{
  pre[cur] = 1
 }
 return pre
},{})
console.log(arrResult) // 结果:{liang: 3, qi: 2, ge: 1}

3.对对象的属性求和

const myArr = [
 {
  name: 'liangqi',
  weigth: 55
 },{
  name: 'mingming',
  weigth: 66
 },{
  name: 'lele',
  weigth: 77
 }
]
const result = myArr.reduce((a,b) =>{
 a = a + b.weigth
 return a
},0)
console.log(result) // 结果:198

Array.of()方法:用于将一组值转化为新数组

举例:

Array.of() // []
Array.of(undefined) // [undefined]
Array.of(1) // [1]
Array.of(1, 2) // [1, 2]

flat()方法:数组拍平方法也叫数组扁平化、数组拉平、数组降维,用于将嵌套的数组变成一维数组,返回一个新数组

举例:

const myArr = [1, [2, 3, [4, 5, [12, 3, "zs"], 7, [8, 9, [10, 11, [1, 2, [3, 4]]]]]]]
console.log(myArr.flat(Infinity)) // [1, 2, 3, 4, 5, 12, 3, "zs", 7, 8, 9, 10, 11, 1, 2, 3, 4]

总结

到此这篇关于JS新手入门数组处理的文章就介绍到这了,更多相关JS数组处理内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
第一个JavaScript入门基础 document.write输出
Feb 22 Javascript
jQuery菜单插件用法实例
Jul 25 Javascript
超实用的javascript时间处理总结
Aug 16 Javascript
微信小程序前端源码逻辑和工作流
Sep 25 Javascript
angular基于路由控制ui-router实现系统权限控制
Sep 27 Javascript
原生js实现放大镜效果
Jan 11 Javascript
js轮播图透明度切换(带上下页和底部圆点切换)
Apr 27 Javascript
详解Vue中过度动画效果应用
May 25 Javascript
JavaScript常见事件处理程序实例总结
Jan 05 Javascript
layui的面包屑或者表单不显示的解决方法
Sep 05 Javascript
vue3 源码解读之 time slicing的使用方法
Oct 31 Javascript
Moment的feature导致线上bug解决分析
Sep 23 Javascript
vue backtop组件的实现完整代码
一文帮你理解PReact10.5.13源码
JS一分钟在github+Jekyll的博客中添加访问量功能的实现
给原生html中添加水印遮罩层的实现示例
html实现随机点名器的示例代码
如何利用JavaScript实现二叉搜索树
(开源)微信小程序+mqtt,esp8266温湿度读取
You might like
php 读取文件乱码问题
2010/02/20 PHP
php获取当前页面完整URL地址
2015/12/30 PHP
详解HTTP Cookie状态管理机制
2016/01/14 PHP
jquery 全局AJAX事件使用代码
2010/11/05 Javascript
分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容
2012/04/20 Javascript
千分位数字格式化(用逗号隔开 代码已做了修改 支持0-9位逗号隔开)的JS代码
2013/12/05 Javascript
轻松创建nodejs服务器(2):nodejs服务器的构成分析
2014/12/18 NodeJs
jquery中filter方法用法实例分析
2015/02/06 Javascript
各种选择框jQuery的选中方法(实例讲解)
2017/06/27 jQuery
JS实现匀加速与匀减速运动的方法示例
2017/09/04 Javascript
jQuery读取本地的json文件(实例讲解)
2017/10/31 jQuery
详解vue axios二次封装
2018/07/22 Javascript
微信小程序实现日期格式化和倒计时
2020/11/01 Javascript
Ant Design的可编辑Tree的实现操作
2020/10/31 Javascript
[02:04]2014DOTA2国际邀请赛 DK一个时代的落幕
2014/07/21 DOTA
[01:33]真香警告!DOTA2勇士令状不朽珍藏Ⅱ饰品欣赏
2018/06/26 DOTA
[02:23]1个至宝=115个英雄特效 最“绿”至宝拉比克“魔导师密钥”登场
2018/12/29 DOTA
在Python中使用异步Socket编程性能测试
2014/06/25 Python
Python进行数据提取的方法总结
2016/08/22 Python
python pandas 时间日期的处理实现
2019/07/30 Python
基于Python实现签到脚本过程解析
2019/10/25 Python
python 安装移动复制第三方库操作
2020/07/13 Python
python实现简单猜单词游戏
2020/12/24 Python
如何用用Python将地址标记在地图上
2021/02/07 Python
HTML5地理定位_动力节点Java学院整理
2017/07/12 HTML / CSS
澳大利亚自然和有机的健康美容产品一站式商店:Ziani Beauty
2017/12/28 全球购物
澳大利亚在线批发商:Simply Wholesale
2021/02/24 全球购物
市场营销管理制度
2014/01/29 职场文书
《乞巧》教学反思
2014/02/27 职场文书
讲座主持词
2014/03/20 职场文书
学校创先争优活动总结
2014/08/28 职场文书
戒赌保证书
2015/05/11 职场文书
2015年乡镇平安建设工作总结
2015/05/13 职场文书
2015年林业工作总结
2015/05/14 职场文书
机关干部正风肃纪心得体会
2016/01/15 职场文书
80行代码写一个Webpack插件并发布到npm
2021/05/24 Javascript