Map 数据结构

目录

一、概念

二、

1、属性和操作方法

2、遍历

3、与其他数据结构的相互转换

(1)、Map 转为数组

(2)、 数组转为 Map 

(3)、Map 转为对象

(4)、对象转为 Map


一、概念

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

二、
1、属性和操作方法
  • size           返回 Map 的元素的个数。
  • set()           增加一个新元素,返回当前的 Map。
  • get()           返回键名对象的键值。
  • delete()     删除某个元素的键名,返回 Boolean 值。
  • has()          检测 Map 中是否包含某个元素,返回 Boolean 值。
  • clear()        清空集合,返回undefined 。
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 所有成员。
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 转为数组

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

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

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

// [ [ true, 7 ], [ { foo: 3 }, [ 'abc' ] ] ]
(2)、 数组转为 Map 
const map = new Map([
  [1, 'one'],
  [2, 'two'],
  [3, 'three'],
]);
console.log(map)
//  {1 => 'one', 2 => 'two', 3 => 'three'}
(3)、Map 转为对象
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
let obj = {"a":1, "b":2};
let map = new Map(Object.entries(obj));

console.log(map) //  {'a' => 1, 'b' => 2}
 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大大大大大白呢

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值