MST

ES6 map && set

2019-05-27  本文已影响0人  hengking

之前我们记录过一些常用的ES6属性,常用ES6总结,今天再来学习两个虽然不是太常见但是用起来非常好用的两个属性。

实际开发过程中经常会遇到去重的问题,往往我们需要写很多代码才能实现,比如遍历、排序等来实现。现在我们可以通过ES6的set来实现了,只需一行代码,轻松搞定:

const set = new Set([1, 2, 3, 4, 4]);
[...set] // [1, 2, 3, 4]

不过,要注意的是,set的去重只能是对数组生效,对象无效。

  1. add()

对set对象添加数据

   let set = new Set()
   set.add(1)
   set.add(2)
   console.log(set) // Set(2) {1, 2}
   console.log([...set]) // [1, 2]
  1. delete(key)

删除set对象中某一个数据,如果不存在不会受影响

   let set = new Set()
   set.add(1)
   set.add(2)
   set.add(3)
   set.delete(1)
   console.log(set) // Set(2) {2, 3}
   console.log([...set]) // [2, 3]
  1. has(key)

判断set对象中是否有某一数据

    let set = new Set()
    set.add(1)
    set.add(2)
    set.add(3)
    set.has(1) // true
    set.has(4) // false
  1. claer()

清除set对象中所有数据

    let set = new Set()
    set.add(1)
    set.add(2)
    set.add(3)
    console.log(set); // Set(3) {1, 2, 3}
    set.clear()
    console.log(set); // Set(0) {}  
  1. entries()

返回一个新的迭代器对象,类似 [value, value] 形式的数组

    let set = new Set()
    set.add(1)
    set.add(2)
    let setIter = set.entries()
    console.log(setIter.next().value); // [1, 1]
    console.log(setIter.next().value); // [2, 2]
  1. keys()

获取set对象值

    let set = new Set()
    set.add(1)
    set.add(2)
    let setIter = set.keys()
    console.log(setIter.next().value); // 1
    console.log(setIter.next().value); // 2
  1. values()

也是获取set对象值

    let set = new Set()
    set.add(1)
    set.add(2)
    let setIter = set.values()
    console.log(setIter.next().value); // 1
    console.log(setIter.next().value); // 2
  1. (callbackFn[, thisArg])

针对集合中的每个元素执行提供的callback函数一次

  1. [@@iterator]()

与values()/keys()类似

    let set = new Set()
    set.add(1)
    set.add(2)
    let setIter = set[Symbol.iterator]()
    console.log(setIter.next().value); // 1
    console.log(setIter.next().value); // 2

对set进行操作以后并不是返回数组,还需要通过展开符或者遍历赋给数组。

size() 获取set对象长度,类似于数组length属性

在ES6之前,JavaScript没有map对象,只能用key-value的形式,ES6提供了map()对象。

map对象和set对象很像

  1. set(key, value)

对map对象添加数据

let map = new Map()
map.set(1, 'one')
map.set(2, 'two')
console.log(map) // Map(2) {1 => "one", 2 => "two"}

  1. delete(key)

删除map对象数据

let map = new Map()
map.set(1, 'one')
map.set(2, 'two')
console.log(map) // Map(2) {1 => "one", 2 => "two"}
map.delete(1)
console.log(map); // Map(1) {2 => "two"}
  1. get(key)

获取map对象某项值

let map = new Map()
map.set(1, 'one')
map.set(2, 'two')
const value1 = map.get(1)
console.log(value1); // one
  1. clear()

删除map对象所有值

let map = new Map()
map.set(1, 'one')
map.set(2, 'two')
console.log(map) // Map(2) {1 => "one", 2 => "two"}
map.clear()
console.log(map); // Map(0) {}
  1. has(key)

判断map对象是否有某个key

let map = new Map()
map.set(1, 'one')
map.set(2, 'two')
console.log(map.has(1)); // true
console.log(map.has(3)); // false
  1. entries()
let map = new Map()
map.set(1, 'one')
map.set(2, 'two')
const mapIter = map.entries()
console.log(mapIter.next().value); // [1, "one"]
console.log(mapIter.next().value); // [2, "two"]
  1. keys()
let map = new Map()
map.set(1, 'one')
map.set(2, 'two')
const mapIter = map.keys()
console.log(mapIter.next().value); // 1
console.log(mapIter.next().value); // 2
  1. values()
let map = new Map()
map.set(1, 'one')
map.set(2, 'two')
const mapIter = map.values()
console.log(mapIter.next().value); // one
console.log(mapIter.next().value); // two
  1. forEach(callbackFn[, thisArg])

和set相同

  1. [@@iterator]()

和set相同

let map = new Map()
map.set(1, 'one')
map.set(2, 'two')
const mapIter = map[Symbol.iterator]()
console.log(mapIter.next().value); // [1, "one"]
console.log(mapIter.next().value); // [2, "two"]

size() 获取map对象长度,类似于数组length属性

上一篇 下一篇

猜你喜欢

热点阅读