ES6-Set-Map对象小记

Set 对象

添加元素

js 复制代码
set.add(value)

常用方法

方法 描述
has() 判断 Set 对象中特定元素是否存在
delete() Set 对象中删除指定元素
clear() 清空 Set 对象

遍历方法

很容易想到使用set.forEach(callBackFn, thisArg)方法来进行遍历,其中callBackFn回调的形式如下:

js 复制代码
set.forEach(function (value, key, set) {
  // value为set中的元素值
  // key与value相同
  // set对象本身
}, thisArg)
//  thisArg 为this对象,为可选参数

回调的参数依次为:

  • value
  • key
  • set

其中,为了和其他有key的对象保持一致,这里使用的value占位了第二个参数,所以key就是value的值。

Map 对象

创建方法

js 复制代码
// 伪代码:
new Map()
new Map(可迭代对象)

// 实际代码的演示:
const map = new Map([['book', 3], ['pen', 5]])
console.log(map)

通常会传入一个二维数组作为可迭代对象,每个一位数组都是一个两元素的小数组,作为可迭代对象的键值对。

添加元素

js 复制代码
// 伪代码
map.set(键, 值);

// 实际代码的演示:
const map = new Map()
map.set([1, 2, 3], '书籍')
map.set(false, '日用品')
map.set(3, '化妆品')
console.log(map)

获取元素

js 复制代码
// 伪代码:
map.get(key)

// 实际演示:
const map = new Map()
map.set(false, '日用品')
console.log(map)

const item = map.get(false)
console.log(item)

常用方法

方法 描述
has() 判断 Map 对象中指定键对应的条目是否存在
delete() Map 对象中删除指定键对应的条目
clear() 清空 Map 对象

对应的实例:

js 复制代码
let bookstore = new Map()
bookstore.set('《活着》', '余华')
bookstore.set('《平凡的世界》', '路遥')
bookstore.set('《三体》', '刘欣慈')
bookstore.set('《猫和老鼠》', '电影')
console.log('《活着》是否存在:', bookstore.has('《活着》'))

bookstore.delete('《猫和老鼠》')
console.log('《猫和老鼠》是否存在:', bookstore.has('《猫和老鼠》'))

bookstore.clear()
console.log(bookstore)

遍历方法

其中callBackFn回调中的参数依次为value,key,map自身,可以看得出来,ES6forEach方法参数上的统一性。

js 复制代码
// 伪代码:
map.forEach(callbackFn, thisArg)

// 参考示例:
const userName = new Map([[1, '小红'], [2, '小蓝'], [3, '小白']])
userName.forEach(function (value, key) {
  console.log('当前条目的键为:', key)
  console.log('当前条目的值为:', value)
})

结语

实际上,还有weakSetweakMap这两种垃圾回收机制更强的弱引用SetMap,本文不再展开。

相关推荐
JamesGosling66611 分钟前
深入理解内容安全策略(CSP):原理、作用与实践指南
前端·浏览器
不要想太多13 分钟前
前端进阶系列之《浏览器渲染原理》
前端
Robet16 分钟前
TS和JS成员变量修饰符
javascript·typescript
方法重载18 分钟前
前端性能优化之“代码分割与懒加载”)
javascript
七喜小伙儿24 分钟前
第2节:趣谈FreeRTOS--打工人的日常
前端
我叫张小白。27 分钟前
Vue3 响应式数据:让数据拥有“生命力“
前端·javascript·vue.js·vue3
laocooon52385788627 分钟前
vue3 本文实现了一个Vue3折叠面板组件
开发语言·前端·javascript
IT_陈寒1 小时前
React 18并发渲染实战:5个核心API让你的应用性能飙升50%
前端·人工智能·后端
科普瑞传感仪器1 小时前
从轴孔装配到屏幕贴合:六维力感知的机器人柔性对位应用详解
前端·javascript·数据库·人工智能·机器人·自动化·无人机
n***F8751 小时前
SpringMVC 请求参数接收
前端·javascript·算法