ES6--数据结构Map

1. Map由来

  • 字典:是用来存储不重复key的Hash结构。不同于集合(Set)的是,字典使用的是[键,值]的形式来储存数据的。
  • JavaScript 的对象(Object:{})只能用字符串当作键。这给它的使用带来了很大的限制。
    举个栗子
var data1 = {a: 1}, data2 = {b: 2}, obj = {};
obj[data1] = 1;
obj[data2] = 2;
console.log(obj);//打印的值只有2 
console.log(data1.toString() === data2.toString());//true
  • 为了解决这个问题,ES6提供了Map数据结构。它类似于对象,也是键值对的集合,但是“键”的范围不限于字符串,各种类型的值(包括对象)都可以当作键。也就是说,Object结构提供了“字符串—值”的对应,Map结构提供了“值—值”的对应,是一种更完善的Hash结构实现。如果你需要“键值对”的数据结构,Map比Object更合适。

2. 详解Map

1) 如何创建一个 Map

const map = new Map([
  ['a', 1],
  ['b', 2]
]);
console.log(map);//Map(2){'a'=>1,'b'=>2}

2) Map 类的属性

const map = new Map([
  ['a', 1],
  ['b', 2]
]);
console.log(map.size);//2

3) Map 类的方法
① set(key, value) 设置键名key对应的键值为value,然后返回整个 Map 结构。如果key已经有值,则键值会被更新,否则就新生成该键。

map.set('miaov', 'ketang').set('new', 'fq').set('miaov', 'leo');
console.log(map);//Map(4){'a'=>1,'b'=>2,'miaov'=>'ketang'...}

若有重复添加的,则后面的覆盖前面的,如后面添加的map.set(’miaov’,’leo’)则会覆盖set(‘miaov’, ‘ketang’)

② get(key) get方法读取key对应的键值,如果找不到 key,返回undefined。

console.log(map.get('new'));//fq
console.log(map.get('x'));//undefined

③ delete(key) 删除某个键,返回true。如果删除失败,返回false。

console.log(map.delete('a'));
console.log(map);
console.log(map.delete('a'));

④ has(key) 方法返回一个布尔值,表示某个键是否在当前Map对象之中。

console.log(map.has('miaov'));
console.log(map.has('a'));

⑤ clear() 清除所有数据,没有返回值。

map.clear();
console.log(map);

⑥ keys() 返回键名的遍历器

console.log(map.keys());

⑦ values() 返回键值的遍历器

console.log(map.values());

⑧ entries() 返回键值对的遍历器

console.log(map.entries());//{['b',2],['miaov','leo']}

⑨ forEach() 使用回调函数遍历每个成员

map.forEach(function (key, value, map){
console.log(key + ':' + value);
})//2;b   leo;miaov

3. 注意事项

Map 在使用过程中的一些注意事项:

map.set(NaN, 10).set(NaN, 100);
console.log(map);//NaN=>100
map.set({}, 'x').set({}, 'y');
console.log(map);//{}=>'x',{}=>'y'
console.log({} === {});//false 引用数据类型比较的是实际的地址,而不是值

map里面的key的排列顺序是按照添加顺序进行排列的

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值