码迷,mamicode.com
首页 > Web开发 > 详细

JS的基本数据类型symbol

时间:2020-02-26 21:15:45      阅读:144      评论:0      收藏:0      [点我收藏+]

标签:全局   lse   访问   property   OLE   key   个数   console   注册   

这是一种在ES6 中新添加的数据类型

Symbol 本质上是一种唯一标识符,可用作对象的唯一属性名,这样其他人就不会改写或覆盖你设置的属性值。
声明方法:

let id = Symbol("id“);

Symbol 数据类型的特点是唯一性,即使是用同一个变量生成的值也不相等。

let id1 = Symbol(‘id‘);
let id2 = Symbol(‘id‘);
console.log(id1 == id2); //false

Symbol 数据类型的另一特点是隐藏性,for···in,object.keys() 不能访问

let id = Symbol("id");
let obj = {
[id]:‘symbol‘
};
for(let option in obj){
console.log(obj[option]); //空
}

但是也有能够访问的方法:Object.getOwnPropertySymbols
Object.getOwnPropertySymbols 方法会返回一个数组,成员是当前对象的所有用作属性名的 Symbol 值。

let id = Symbol("id");
let obj = {
[id]:‘symbol‘
};
let array = Object.getOwnPropertySymbols(obj);
console.log(array); //[Symbol(id)]
console.log(obj[array[0]]); //‘symbol‘

虽然这样保证了Symbol的唯一性,但我们不排除希望能够多次使用同一个symbol值的情况。
为此,官方提供了全局注册并登记的方法:Symbol.for()

 

let name1 = Symbol.for(‘name‘); //检测到未创建后新建
let name2 = Symbol.for(‘name‘); //检测到已创建后返回
console.log(name1 === name2); // true

 

通过这种方法就可以通过参数值获取到全局的symbol对象了,反之,能不能通过symbol对象获取到参数值呢?
是可以的 ,通过Symbol.keyFor()

let name1 = Symbol.for(‘name‘);
let name2 = Symbol.for(‘name‘);
console.log(Symbol.keyFor(name1)); // ‘name‘
console.log(Symbol.keyFor(name2)); // ‘name‘

https://blog.csdn.net/qq_33408245/article/details/82953143

 

JS的基本数据类型symbol

标签:全局   lse   访问   property   OLE   key   个数   console   注册   

原文地址:https://www.cnblogs.com/zfj6666/p/12368753.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!