javaScript - Set/WeakSet
Posted 火腿肠烧烤大赛冠军
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javaScript - Set/WeakSet相关的知识,希望对你有一定的参考价值。
什么是set
- 与数组类似,但是其中不可以存放相同的值
// let arr = [1, 1, 1, 1, 1, 1];
// console.table(arr);
// let set = new Set([1, 2, 3, 4, 5]);
// set.add(1);
// set.add("1");
// console.log(set);//1
- 与对象区别
对象数字、字符串都被视为一个,无法重复
set中严格校验可以相同 - set的创建
let set = new Set([‘name’,‘sam’]);
如果是字符串:
则会解析成【‘n’,‘a’,‘m’,‘e’】; - set的各种方法
- set.clear(): 清空set(彻底删除set)
- set.delete(‘name’): 删除某个元素
- set.size: 查看set大小(长度)
- set.value: 查看set内容
- set.has(item): set中是否含有该元素
- set.add(1): 增加新元素
set的妙用
tips:set类似数组也可以被。。。解构
数组去重
let arr = [1, 2, 3, 4, 1, 2, 3];
// 将其转换为set
let set = new Set(arr);
console.log([...set]);
set类型遍历
和数组一样一样的
forEach、for of 、三个迭代器、别的没试
set处理交并补
并:set = new Set([…a,…b]);
交:
let set = new Set({
[...a].filter(ele => {
return b.has(ele);
})
})
补:
let set = new Set({
[...a].filter(ele => {
return !b.has(ele);
})
})
WeakSet
- 除了一个放引用,一个放值 莫得区别
- 弱引用类型:
如果强引用被删除,则自动清空 - 由于2的原因,所以所有的遍历、size等操作会直接禁止。
以上是关于javaScript - Set/WeakSet的主要内容,如果未能解决你的问题,请参考以下文章
es6之数据结构 set,WeakSet,mapWeakMap
JavaScript 代写代写JavaScript 编程作业用JavaScript 做mazeJavaScript语言代写