js ES6的Set 对象

大家好,我是pkqk,废话不多说直接上代码来更好的了解 Set 对象。

//创建Set 对象
	let set=new Set();
	/* 里面可以直接传null,undefined,字符串,数组。
	其他类型要用[]数组的形式来传值 */
	let a=new Set([{1:"a"}]);
	console.log(a);
	let b=new Set([1]);
	console.log(b);
	let c=new Set([Symbol(1)]);
	console.log(c);
	let d=new Set([NaN]);
	console.log(d);
	
	set.add(Symbol(1));
	console.log(set);
	/* 但要注意的是 Set 对象的add
	可以直接传任意类型的值*/

 类型转换

// Set 对象 类型转换
	// Array 转 Set
	var a = new Set(["1", "2", "3"]);
	// 用...操作符,将 Set 转 Array
	var b = [...a];
	console.log(b);
	

Set 对象最大的作用是数组去重,讲到去重就要谈到Set中的特殊值

Set 对象存储的值总是唯一的,所以需要判断两个值是否恒等。有几个特殊值需要特殊对待:

+0 与 -0 在存储判断唯一性的时候是恒等的,所以不重复;

undefined 与 undefined 是恒等的,所以不重复;

NaN 与 NaN 是不恒等的,但是在 Set 中只能存一个,不重复;

ES6 引入了一种新的原始数据类型 Symbol ,表示独一无二的值,Symbol类型的值是唯一的,是不恒等的,所以不重复。

let a=new Set([Symbol(1),Symbol(1)]);
	console.log(a);

接下来看去重

var a = new Set([1, 2, 3, 4, 4,-0,+0,undefined,undefined,NaN,Number("not a number"),Symbol("1"),Symbol("1")]);
	console.log([...a]);//转成 Array 类型
//结果:[1, 2, 3, 4, 0, undefined, NaN, Symbol(1), Symbol(1)]

谢谢大家的观看!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值