Symbol数据类型
概念:这种数据类型提供一个独一无二的值,也就是说Symbol声明的变量a和变量b永远不可能相等。
声明
let a = Symbol();
let b = Symbol();
console.log(a === b); //false
它自己都不会等于它自己
Symbol.for
let c = Symbol.for("aaa");
let d = Symbol.for("aaa");
console.log(c === d); //true
Symbol.for和Symbol的唯一区别是 Symbol.for创建的两个实例可能相等, 根据Symbol的参数生成实例, 如果参数一样, 那么会返回同一个实例。
看到这里,还完全不知道要怎么使用,不急不急,接下来。。。
使用:
let a = Symbol.for('abc');
let obj = {
[a]:'111',
'abc':222,
'b':333
};
console.log('obj',obj);//{abc: 222, b: 333, Symbol(abc): "111"}
console.log(Symbol.keyFor(a)); // abc 检索字符串键
这种使用就可以避免对象中键值相同替换的问题
但是这样使用会有一个问题,对象中使用Symbol做键值,通过for in 和 let of是拿不到那个属性。
···
for(let [key,value] of Object.entries(obj)){
console.log('entries',key,value);//abc 222;b 333
}
···
解决方法: Object.getOwnPropertySymbol()返回值是数组, 但是这个只能打印出Symbol做键值的值,这就尴尬了,下面使用reflect.ownKeys来解决这个问题
Object.getOwnPropertySymbols(obj).forEach(function (item) {
console.log('getOwnPropertySymbols', obj[item]);//111
});
reflect.ownKeys()返回的也是数组
Reflect.ownKeys(obj).forEach(function (item){
console.log('ownKeys', item, obj[item]);
/*ownKeys abc 222
* ownKeys b 333
* ownKeys Symbol(abc) 111
* */
});
到这里也感觉了解甚浅,后面有机会补充。