Map与Set,ES6新增的数据类型

js的默认对象{}可以视为其它语言的map后者dictionary,即一组键值对,但是js的对象的键必须是字符串,非常的不合理,其它数据类型应该也是可以的,所以在es6中引入了Map与Set,可以通过以下方式来检测浏览器是否Map与Set;

'use strict';
var m = new Map();
var s = new Set();
console.log('你的浏览器支持Map和Set!');

Map:
Map是一组键值对结构,具有极快的查询速度,比如想要数组来查询学生成绩的话,需要两个数组,先搜寻学生名单,再比对学生成绩;但是使用Map的话可以同时引入学生与成绩;

var name=["David","Wei","Fuck"];
var score=[10,20,30];
//使用Map
var score=new Map([["David",10],["Wei",20],["Fuck",30]]);
score.get("David");//10

//初始化Map需要一个二维数组或者初始化一个空Map
var m = new Map(); // 空Map
m.set('Adam', 67); // 添加新的key-value
m.set('Bob', 59);
m.has('Adam'); // 是否存在key 'Adam': true
m.get('Adam'); // 67
m.delete('Adam'); // 删除key 'Adam'
m.get('Adam'); // undefined

Set
与Map相同,也是键的集合,但是没有value,并且因为键不能重复,所以可以用来给数组去重,而要创建一个Set,需要输入数组,或者创建一个空Set;

var s1 = new Set(); // 空Set
var s2 = new Set([1, 2, 3]); // 含1, 2, 3

//重复元素会自动过滤
var s = new Set([1, 2, 3, 3, '3']);
s; // Set {1, 2, 3, "3"}

//通过add可以添加元素,delete可以删除元素
s.add(4);
s; // Set {1, 2, 3, 4}
s.add(4);
s; // 仍然是 Set {1, 2, 3, 4}

var s = new Set([1, 2, 3]);
s; // Set {1, 2, 3}
s.delete(3);
s; // Set {1, 2}

//关于具体利用Set去重数组方法;
var arr=[1,2,1,2,3];
console.log("初始数组:"+arr);

var s=new Set(arr);
console.log(s);

var arr2=Array.from(s);
console.log("去重后的数组:"+arr2);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值