浅谈ES6新增的数组方法和对象
程序员文章站
2022-11-25 10:34:20
es6新增的遍历数组的方法,后面都会用这个方法来遍历数组,或者对象,还有set,map
let arr=[1,2,3,4,3,2,1,2];
遍历数组最简洁...
es6新增的遍历数组的方法,后面都会用这个方法来遍历数组,或者对象,还有set,map
let arr=[1,2,3,4,3,2,1,2];
遍历数组最简洁直接的方法
for (let value of arr) { console.log(value);//输出1,2,3,4,3,2,1,2 }
1. 数组.map()
返回一个新的数组,es5要复制一个新的数组我们一般用循环,现在直接用map
let arr=[1,2,3,4,3,2,1,2]; let newarr=arr.map((value,index,arr)=>value) console.log(newarr)//输出[1,2,3,4],当然里面也可以返回下标的数组 console.log(newarr==arr)//输出false
2. 数组.filter()
过滤,返回为真的值,
let arr=[1,2,3,4,3,2,1,2]; let newarr1=arr.filter((value,index,arr)=>value>=3) console.log(newarr1);//输出[3,4,3]
3. 数组.reduce()
每个参数的意思previousvalue上次回调的返回值或者初始值,currentvalue正在处理的数组值,currentindex正在处理函数的下标
//以前找最大值,最小值我们是用的2层循环来找的,现在直接一行代码搞定,是不是很爽 let arr=[1,2,3,4,3,2,1,2]; let newarr2=arr.reduce((pre,cur,curindex,arr)=>pre>cur?pre:cur) //pre=1不大于cur=2,返回2; //pre接收返回值2;pre=2不大于cur=3,返回3 ..... //一直找到4并且返回4; //pre接收4,pre=4大于pre=3然后就一直返回的都是4,这样就会找到最大值 console.log(newarr2)//输出4,找到最大值,如果想找最小值只需要pre<cur?pre:cur
es6提供的一种新的数据结构,它类似于数组,但是成员的值都是唯一的,没有重复的值(包括nan),但是set内部对象是不相等的
set不是数组,自然就没有length属性,它有size属性,set.size,就是返回它的成员数量;
let set=new set([1,2,3,4,3,2,1]);//这里必须传入的是数组 console.log(set)//输出set {1,2,3,4} console.log(set.add(2))//依然输出set {1,2,3,4} console.log(set.add(5))//输出 set {1,2,3,4,5} console.log(set.delete(1))//输出true,表示删除成功 console.log(set.has(2))//输出true,表示存在这个值 console.log(set.clear())//输出undefined,这个方法知识删除所有值,并没有返回值 console.log(set)//这时候set已经清空了,所以输出为 set {}
array.from()方法从一个类似数组或可以迭代的对象中创建一个新的数组实例
let set=new set([1,2,3,4,3,2,1]); console.log(array.from(set))//用这个方法就可以把set对象转换我数组,输出为[1,2,3,4,3,2,1] console.log(array.from('hello'))//输出为['h','e','l','l','o']
利用set 和 from达到数组去重
let arr1=[1,2,2,1,1,3,5,2] console.log(array.from(new set(arr1)))//输出[1,2,3,5],以后别人问你怎么数组去重,你可以装下逼了
写到这里突然想到es6的...方法
console.log([...new set(arr1)])
set的遍历方法
for (let value of set.keys()) { console.log(value)//输出键 } for (let value of set.values()) { console.log(value)//输出值 } for (let value of set.entries()) { console.log(value)//输出键值对 }
es6提供了map数据结构,它类似于对象,也是键值对的集合,但是它的强大在于键的范围可以任何类型的数据;
let map=new map([["name","张三"],[[1,2,3],18],[{},"男"]]) console.log(map) console.log(map.set("name","李四"))//输出 map { 'name' => '张三', [ 1, 2, 3 ] => 18, {} => '男' }如果没有这个键,就会添加新的键值对到后面 console.log(map.get("name"))//输出李四 console.log(map.delete("name"))//输出true console.log(map.clear())//删除所有键值对
以上这篇浅谈es6新增的数组方法和对象就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
上一篇: form表单序列化详解(推荐)
推荐阅读
-
Vue实现动态添加或者删除对象和对象数组的操作方法
-
ES6基础之数组和对象的拓展实例详解
-
荐 浅谈Java中类和对象的初始化、实例化以及方法重载的底层机制
-
浅谈ES6新增的数组方法和对象
-
js获取对象,数组所有属性键值(key)和对应值(value)的方法示例
-
ES6--08 数组实例的新增方法和扩展运算符
-
搜索功能(五)03-搜索关键字历史重复记录-数组去重操作——es6 set类数组-数据结构-数组去重 & 三个点(...)方法-对象的延展操作-拆解数组
-
详解JavaScript中的数组合并方法和对象合并方法
-
ES5和ES6新的操作数组的方法(常用)
-
前端的 JavaScript Array(数组) 方法和对象