Symbol 解决对象的属性名冲突
还记得我们熟知的几种数据类型吧!
String Number Object undefined Null
Boolean
现在又多了一种类型就是Symbol
let a=Symbol()
console.log(a)//Symbol()
console.log(typeof a)//symbol
以上代码用一个Symbol()函数创建一个Symbol类型的变量打印a得到的是Symbol().它代表的是独一无二的值
var a1=Symbol()
vat a2=Symbol()
a1===a2//false
可以看出a1和a2是不相等的
Symbol()函数,可以接受参数,即使接受的参数一样,他们也是不相等的
var a1=Symbol("abc")
vat a2=Symbol("abc")
a1===a2//false
当Symbol值作为对象的属性名时候,不能用点运算符获取对应的值,要用中括号,因为用点运算符时候,会导致ja ascript把后面的属性名理解为一个字符串类型而不是Symbol类型
var name=Symbol()
var person={[age]:29}
console.log(person.age)//undefined
console.log(person[age])//29
当Symbol类型的值作为属性名的时候,这个属性是不会被for...in...和for...of...,Object.keys()遍历到,
var person={[name]:"孙悟空","age":500}
Object.keys(person)//age
for(var key in person){
console.log(key)//age
}
如果要获取Symbol类型的属性的话,用getOwnPropertySymbol()函数,只能获取symbol类型的,返回一个数组,数组成员就是symbol类型的属性值
var name=Symbol("name")
var age=Symbol("age")
var person={
[name]:"孙悟空",
[age]:500,
"from":"花果山"
}
Object.getOwnPropertySymbol(person)
//[Symbol(name),Symbol(age)]
Reflect.ownKeys()函数
一次性获取所有类型的属性,不管是字符串还是Symbol类型
var person={
[Symbol("name")]:"猪八戒",
"age":500
}
Reflect.ownKeys(person)
//["age",Symbol(name)]
Symbol.for()函数
根据参数名,去全局环境中搜索是否有以该参数为名的Symbol值,有就返回它,没有就以该参数来创建一个新的Symbol值
var a1=Symbol.for("age")
var a2=Symbol.for("age")
a1===a2//true
Symbol.for()创建的Symbol值会被登记在全局环境中,哄以后Symbol.for()来搜索,而Symbol创建的值,用Symbol.for()是搜索不到的,
Symbol.keyFor()函数
返回一个被登记在全局环境中的Symbol值的key.没有就返回undefined.就是说这个Symbol值是被Symbol.for()创建的
var a=Symbol.for("name)
Symbol.keyFor(a)//name
var a=Symbol("name")
Symbol.keyFor(a)//undefined
还记得我们熟知的几种数据类型吧!
String Number Object undefined Null
Boolean
现在又多了一种类型就是Symbol
let a=Symbol()
console.log(a)//Symbol()
console.log(typeof a)//symbol
以上代码用一个Symbol()函数创建一个Symbol类型的变量打印a得到的是Symbol().它代表的是独一无二的值
var a1=Symbol()
vat a2=Symbol()
a1===a2//false
可以看出a1和a2是不相等的
Symbol()函数,可以接受参数,即使接受的参数一样,他们也是不相等的
var a1=Symbol("abc")
vat a2=Symbol("abc")
a1===a2//false
当Symbol值作为对象的属性名时候,不能用点运算符获取对应的值,要用中括号,因为用点运算符时候,会导致ja ascript把后面的属性名理解为一个字符串类型而不是Symbol类型
var name=Symbol()
var person={[age]:29}
console.log(person.age)//undefined
console.log(person[age])//29
当Symbol类型的值作为属性名的时候,这个属性是不会被for...in...和for...of...,Object.keys()遍历到,
var person={[name]:"孙悟空","age":500}
Object.keys(person)//age
for(var key in person){
console.log(key)//age
}
如果要获取Symbol类型的属性的话,用getOwnPropertySymbol()函数,只能获取symbol类型的,返回一个数组,数组成员就是symbol类型的属性值
var name=Symbol("name")
var age=Symbol("age")
var person={
[name]:"孙悟空",
[age]:500,
"from":"花果山"
}
Object.getOwnPropertySymbol(person)
//[Symbol(name),Symbol(age)]
Reflect.ownKeys()函数
一次性获取所有类型的属性,不管是字符串还是Symbol类型
var person={
[Symbol("name")]:"猪八戒",
"age":500
}
Reflect.ownKeys(person)
//["age",Symbol(name)]
Symbol.for()函数
根据参数名,去全局环境中搜索是否有以该参数为名的Symbol值,有就返回它,没有就以该参数来创建一个新的Symbol值
var a1=Symbol.for("age")
var a2=Symbol.for("age")
a1===a2//true
Symbol.for()创建的Symbol值会被登记在全局环境中,哄以后Symbol.for()来搜索,而Symbol创建的值,用Symbol.for()是搜索不到的,
Symbol.keyFor()函数
返回一个被登记在全局环境中的Symbol值的key.没有就返回undefined.就是说这个Symbol值是被Symbol.for()创建的
var a=Symbol.for("name)
Symbol.keyFor(a)//name
var a=Symbol("name")
Symbol.keyFor(a)//undefined