赞
踩
Set 对象允许你存储任何类型的唯一值,无论是原始值或者是对象引用。
Set 对象存储的值总是唯一的,所以需要判断两个值是否恒等。有几个特殊值需要特殊对待:
代码:
- let mySet = new Set();
-
- mySet.add(1); // Set(1) {1}
- mySet.add(5); // Set(2) {1, 5}
- mySet.add(5); // Set(2) {1, 5} 这里体现了值的唯一性
- mySet.add("some text");
- // Set(3) {1, 5, "some text"} 这里体现了类型的多样性
- var o = {a: 1, b: 2};
- mySet.add(o);
- mySet.add({a: 1, b: 2});
- // Set(5) {1, 5, "some text", {…}, {…}}
- // 这里体现了对象之间引用不同不恒等,即使值相同,Set 也能存储
Array
- // Array 转 Set
- var mySet = new Set(["value1", "value2", "value3"]);
- // 用...操作符,将 Set 转 Array
- var myArray = [...mySet];
- // String 转 Set
- var mySet = new Set('hello'); // Set(4) {"h", "e", "l", "o"}
- // 注:Set 中 toString 方法是不能将 Set 转换成 String
1:数组去重
- var mySet = new Set([1, 2, 3, 4, 4]);
- [...mySet]; // [1, 2, 3, 4]
2:并集
- var a = new Set([1, 2, 3]);
- var b = new Set([4, 3, 2]);
- var union = new Set([...a, ...b]); // {1, 2, 3, 4}
3:交集
- var a = new Set([1, 2, 3]);
- var b = new Set([4, 3, 2]);
- var intersect = new Set([...a].filter(x => b.has(x))); // {2, 3}
-
- // 解析:
- // 1:[..a]
- // [..a]就是将set转换为array
-
- // 2:[..a].filter()
- // Array.filter(function(x))把传入的函数function(x)依次作用域每个元素,x为元素的值,然后根据返回值是true还是false决定保留还是丢弃该元素。
- // 说人话就是,遍历数组Array的元素,若返回值为flase就删除这个元素
- // filter()方法:创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素
-
- // 3:=> 函数简写
- // x => x*x
- // 相当于
- // function(x){return x*x}
-
- // 4:b.has(x)
- // Set.has(x)是set中的一个方法,即判断当前set中是否含有x,如果有则返回 true ,没有则返回 false
-
- //所以上面的代码也就等同于
- var a = new Set([1, 2, 3]);
- var b = new Set([4, 3, 2]);
- var arr = [...a]
- var fArr = arr.filter(function(x){ //使用filter过滤数组,将新数组返会fArr
- return b.has(x) //判断b中是否含有a的元素,没有则返回false
- })
- var intersecct = new Set(fArr) //将fArr转换为set
- console.log(fArr)
4:差集
- var a = new Set([1, 2, 3]);
- var b = new Set([4, 3, 2]);
- var difference = new Set([...a].filter(x => !b.has(x))); // {1}
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。