JavaScript的Symbol类型、隐藏属性及全局注册表详解
本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。
【相关推荐:javascript视频教程、web前端】
Symbol简介
Symbol
类型是JavaScript
中的一种特殊的类型,特殊在所有的Symbol
类型值都互不相同。我们可以使用“Symbol”来表示唯一的值,下面是创建Symbol
对象的案例:
let id = Symbol();
这样我们就创建了一个Symbol
类型的值,并把这个值存储在了变量id
中。
Symbol类型的描述
我们在创建一个Symbol
类型变量的时候,可以在参数中传入一些秒属性的字符串,用于描述这个变量的用途信息。
例如:
let id1 = Symbol('狂拽酷炫吊炸天的小明的id'); let id2 = Symbol('低调奢华有内涵的婷婷的id');
Symbol
类型在任何时候都是不同的,即使他们拥有相同的描述信息,描述只是一个标签,除此之外就没有别的用途了,例如:
let id1 = Symbol('id'); let id2 = Symbol('id'); console.log(id1==id2);//false
这个标签存在的意义,个人认为和Symbol
不能直观的看到内部具体值的特性有关,通过添加一个描述信息,让我们对变量的用途有更直观的了解。
Symbol不会隐式转字符串
JavaScript
中的大多数类型都可以直接转换成字符串类型输出,所以我们不能直观的看到它的值到底是什么,例如我们可以直接用alert(123)
把数字123
转换成字符串弹出。
但是Symbol
类型比较特殊,它不能直接转换,例如:
let id = Symbol(); alert(id);//报错,不能把Symbol类型转为字符串
JavaScript
中的Symbol
类型不能转成字符串是由于其内在的防治语言混乱的“语言保护”机制,因为字符串和Symbol
在本质上有着区别,不应该将其中一个转换成另一个。
试想一下,如果Symbol
可以转为字符串,那么它就变成了一个生成独一无二字符串的函数,就不再具备独立数据类型的必要。
如果我们真的想知道Symbol
变量的值,我们可以使用.toString()
方法,如下所示:
let id = Symbol('this is identification'); console.log(id.toString());//Symbol(this is identification);
或者使用.description
属性,获取描述信息:
let id = Symbol('加油,奥利给'); console.log(id.description);//加油,奥利给”
Symbol类似作为对象的属性键
根据JavaScript
的规范,只有两种类型的值可以作为对象的属性键:
- 字符串
- Symbol
如果使用其他类型,则会隐式的转为字符串类型。对象的键在前面的章节有详细的介绍,这里不再重复。
创建Symbol键
将Symbol
作为键值有两种方法:
例1:
let id = Symbol('id'); let user = {}; user[id] = 'id value';//添加Symbol键 console.log(user[id]);//id value
例2:
let id = Symbol('id'); let user = { [id]:'id value',//注意这里的方括号 }; console.log(user[id]);