ES6 - Symbol

2019-10-15  本文已影响0人  ElricTang

ES6新增了基本数据类型Symbol,最大的特点是每个Symbol都是唯一的。(解决变量冲突问题)

let a = Symbol();
let b = Symbol();
console.log(a === b); // false

一. 使用typeof测试类型时,返回symbol,因为symbol是基本数据类型

console.log(typeof(Symbol()));// symbol

二. 无法对Symbol()使用new,因为Symbol产生的是原始值,而不是包装对象,也意味着无法像对象一样添加属性。

let c = new Symbol();// TypeError: Symbol is not a constructor

三. Symbol()接受参数,用于作为描述(方便区分不同symbol实例)

let tom = Symbol('tom');
let jack = Symbol('jack');
console.log(tom);// Symbol(tom)
console.log(jack);// Symbol(jack)

注意:参数只是描述符,与symbol的值没有关系,相同的参数不会使值相等

console.log(Symbol('a') === Symbol('a'));// false

四. 关于symbol类型转换

console.log('my name is' + Symbol('tom'));
// TypeError: Cannot convert a Symbol value to a string
console.log(Symbol('tom').toString());// Symbol(tom)
console.log(Boolean(Symbol()));// true
console.log(!Symbol());// false
console.log(Symbol(1) + 1);
// TypeError: Cannot convert a Symbol value to a number
console.log(Number(Symbol(1)));
// TypeError: Cannot convert a Symbol value to a number

五. symbol的枚举

const name = Symbol('name');
const age = Symbol('age');

let obj = {
    [name]:'tom',
    [age]:21,
    'hobby':'football'
};

for(let item in obj){
    console.log(item,obj[item]);
}
// hobby football
console.log(Object.getOwnPropertyNames(obj));// [ 'hobby' ]
- 
console.log([name] in obj);
// TypeError: Cannot convert a Symbol value to a string
console.log(obj.hasOwnProperty([name]));
// TypeError: Cannot convert a Symbol value to a string
console.log(JSON.stringify( { name:'tom',[Symbol('age')]:21 } ))
// {"name":"tom"}

六. symbol的应用

const name = Symbol('name');

let obj1 = {};
obj1[name] = 'tom';

let obj2 = {
    [name]:'tom'
};

let obj3 = {};
Object.defineProperty(obj3,name,{
    value:'tom'
});

调用对象中以symbol为属性名的属性时,只能使用[]的方式,不能使用.,定义属性时同理。(因为点运算符默认接字符串)

console.log(obj1.name);// undefined
console.log(obj1[name]);// tom
console.log(obj1['name']);// undefined
上一篇 下一篇

猜你喜欢

热点阅读