ES6 中数组的常用方法
最编程
2024-04-12 08:51:21
...
数组在JS中虽然没有函数地位那么高,但是也有着举足轻重的地位,下面我就结合这ES5中的一些常用的方法,与ES6中的一些方法做一些说明和实际用途。
一、ES5中数组常用方法:
1、循环遍历。
let arr = [1,2,3]
for(let i=0;i<arr.length;i++){
console.log(i) // 1 2 3
}
2、forEach:没有返回值,不能使用break和continue。只是针对每个元素调用Func。
let arr = [1,2,3]
// elem 数组里面的每一项
// index 数组索引
// array 数组
arr.forEach(function(elem,index,array){
console.log(elem,index) // 1 0 2 1 3 2
})
3、map:返回新数组,每个元素为调用Func后的结果。
let arr = [1,2,3]
let result = arr.map(function(val){
val += 1
return val
})
console.log(arr,result) // [1,2,3] [2,3,4]
4、filter:返回符合Func条件的元素数组。
let arr = [1,2,3]
let result = arr.filter(function(val){
return val == 2
})
console.log(arr,result) // [1,2,3] [2]
5、some:返回布尔值,判断是否有元素符合Func条件(有一个满足条件就返回true)。
let arr = [1,2,3]
let result = arr.some(function(val){
return val == 2
})
console.log(arr,result) // [1,2,3] true
6、every:返回布尔值,判断每个元素符合Func条件(全部满足条件才返回true)。
let arr = [1,2,3]
let result = arr.every(function(val){
return val == 2
})
console.log(arr,result) // [1,2,3] false
7、reduce:接收函数作为一个累加器 7-1:累加器
let arr = [1,2,3]
// prev为前一个对象
// cur为当前对象
// index为当前序列
// arr为当前数组
let sum = arr.reduce(function(prev,cur,index,arr){
return prev + cur
},0)
console.log(sum) // 6
7-2、获取数组中最大值。
let arr = [1,2,3]
let max = arr.reduce(function(prev,cur){
Math.max(prev,cur)
})
console.log(max) // 3
7-3、数组去重
let arr = [1,2,3,3]
let res = arr.reduce(function(prev,cur){
prev.indexOf(cur) == -1 && prev.push(cur)
return prev
},[])
console.log(res) // [1,2,3]
8、for...in:遍历数组的时候会将原型下面函数遍历
Array.prototypr.foo = function(){
console.log("foo")
}
let arr = [1,2,3]
for(let index in arr){
console.log(index) // 遍历数组同样会遍历原型下面的函数foo
}
二、ES6中数组常用方法 1、find:返回第一个通过测试的元素
let arr = [1,2,3,4]
let res = arr.find(function(val){
return val > 2
})
console.log(res) // 3
2、findIndex:返回第一个通过测试的元素对应索引
let arr = [1,2,3,4]
let res = arr.find(function(val){
return val > 2
})
console.log(res) // 2
3、for...of
let arr = [1,2,3,4]
for(let item of arr){
console.log(item) // 1 2 3 4
}
3-1、values:仅遍历值
let arr = ["a","b","c","d"]
for(let item of arr.values()){
console.log(item) // "a" "b" "c" "d"
}
3-2、keys:仅遍历index
let arr = ["a","b","c","d"]
for(let item of arr.keys()){
console.log(item) // 0 1 2 3
}
3-3、entries:遍历index和值
let arr = ["a","b","c","d"]
for(let item of arr.entries){
console.log(item) // [0, "a"] [1, "b"] [2, "c"] [3, "d"]
}
推荐阅读
-
我可以恢复手机中已删除的短信吗?答案是肯定的!操作方法非常简单
-
如何恢复手机中已删除的短信?其实很简单!来了解一下这些有效的方法吧
-
实现分布式锁的一般方法有哪些?如何使用 Redis 设计分布式锁?可以使用 zk 设计分布式锁吗?这两种实现分布式锁的方法中,哪一种更有效?
-
Java Swing 中实现为窗体添加背景图像的两种方法说明
-
扁平化数组的六种方法,总有一种适合你
-
14.企业无线网络的几种常用认证方法
-
了解并使用 JAVA 中的 set 和 get 方法
-
Java 中的构造函数(构造方法
-
教姐妹们学Java(二十五):了解Java中的构造方法(1)
-
在 Linux 中启动 redis 的方法有哪些?