Map 数据结构

一、概念

Set 是一种叫【字典(是一些元素的集合,以 [ 键,值 ] 的形式储存)】的数据结构。

二、
1、属性和操作方法
  • size 返回 Map 的元素的个数。
  • set() 增加一个新元素,返回当前的 Map。
  • get() 返回键名对象的键值。
  • delete() 删除某个元素的键名,返回 Boolean 值。
  • has() 检测 Map 中是否包含某个元素,返回 Boolean 值。
  • clear() 清空集合,返回undefined 。
TypeScript 复制代码
const map = new Map();
map.set("foo", "aaaaa"); // {"foo" => 'aaaaa'}
map.set("bar", "bbbbb"); // {"foo" => 'aaaaa'}

map.size; // 2
map.get("foo"); // aaaaa
map.has("foo"); // true
map.delete("bar"); // true
map.clear() // 数据清空  undefined
2、遍历
  • keys() 返回键名。

  • values() 返回键值。

  • entries() 返回所有成员。

  • forEach() 遍历 Map 所有成员。

TypeScript 复制代码
const map = new Map([
  ['F', 'no'],
  ['T',  'yes'],
]);

for (let key of map.keys()) {
  console.log(key);
}
// "F"
// "T"

for (let value of map.values()) {
  console.log(value);
}
// "no"
// "yes"

for (let item of map.entries()) {
  console.log(item[0], item[1]);
}
// "F" "no"
// "T" "yes"

// 或者
for (let [key, value] of map.entries()) {
  console.log(key, value);
}
// "F" "no"
// "T" "yes"

// 等同于使用map.entries()
for (let [key, value] of map) {
  console.log(key, value);
}
// "F" "no"
// "T" "yes"


map.forEach(function(value, key, map) {
 console.log( key, value);
});

 // "F" "no"
 // "T" "yes"
3、与其他数据结构的相互转换
(1)、Map 转为数组

使用运算扩展符 【...】

TypeScript 复制代码
const myMap = new Map().set(true, 7).set({ foo: 3 }, ["abc"]);

console.log([...myMap]);

// [ [ true, 7 ], [ { foo: 3 }, [ 'abc' ] ] ]
(2)、 数组转为 Map
TypeScript 复制代码
const map = new Map([
  [1, 'one'],
  [2, 'two'],
  [3, 'three'],
]);
console.log(map)
//  {1 => 'one', 2 => 'two', 3 => 'three'}
(3)、Map 转为对象
TypeScript 复制代码
const strMapToObj = (strMap) => {
  let obj = Object.create(null);
  for (let [k, v] of strMap) {
    obj[k] = v;
  }
  console.log(obj); //  { yes: true, no: false }
  return obj;
};

const myMap = new Map().set("yes", true).set("no", false);
strMapToObj(myMap);
(4)、对象转为 Map
TypeScript 复制代码
let obj = {"a":1, "b":2};
let map = new Map(Object.entries(obj));

console.log(map) //  {'a' => 1, 'b' => 2}
 
相关推荐
书语时1 小时前
ES6 Promise 状态机
前端·javascript·es6
lexiangqicheng1 天前
es6+和css3新增的特性有哪些
前端·es6·css3
漫谈网络2 天前
TypeScript 编译 ES6+ 语法到兼容的 JavaScript介绍
javascript·typescript·es6
书语时6 天前
ES6 深克隆与浅克隆详解:原理、实现与应用场景
前端·javascript·es6
一轮大月亮8 天前
JavaScript es6 语法 map().filter() 链式调用,语法解析 和常见demo
开发语言·javascript·es6
zlpzlpzyd12 天前
ecmascript 第6版特性 ECMA-262 ES6
前端·ecmascript·es6
电子科技圈12 天前
XMOS推出支持AES67标准的以太网音频解决方案——使高兼容性和低延迟专业音频传输及播放成为可能
前端·es6·音视频
超级土豆粉13 天前
ES6 扩展运算符与 Rest 参数
前端·ecmascript·es6
theMuseCatcher14 天前
手写ES6 Promise() 相关函数
javascript·es6
超级土豆粉15 天前
ES6 哈希数据结构
数据结构·es6·哈希算法