Symbol类型
-
- Symbol
-
- [1. 自ECMAScript 2015起,symbol成为了一种新的原生类型,就像number和string一样。](#1. 自ECMAScript 2015起,symbol成为了一种新的原生类型,就像number和string一样。)
-
- [1.1. symbol类型的值是通过Symbol构造函数创建的。](#1.1. symbol类型的值是通过Symbol构造函数创建的。)
- [1.2. 可以传递参做为唯一标识 只支持 string 和 number类型的参数](#1.2. 可以传递参做为唯一标识 只支持 string 和 number类型的参数)
- [2. Symbol的值是唯一的。](#2. Symbol的值是唯一的。)
-
- [2.1. Symbol的值是唯一的](#2.1. Symbol的值是唯一的)
- [2.2. Symbol.for可以获取到相同的值](#2.2. Symbol.for可以获取到相同的值)
- [2.3 Symbol.for和Symbol的区别:for在全局Symbol里面找有没有注册过这个key, 如果有直接拿来用, 没有的话就创建一个](#2.3 Symbol.for和Symbol的区别:for在全局Symbol里面找有没有注册过这个key, 如果有直接拿来用, 没有的话就创建一个)
- [3. Symbol的使用场景。](#3. Symbol的使用场景。)
-
- [3.1. symbol的key值一样不覆盖对象的属性](#3.1. symbol的key值一样不覆盖对象的属性)
- [4. symbol定义属性的获取](#4. symbol定义属性的获取)
-
- [4.1. 使用symbol定义的属性,是不能通过如下方式拿到的](#4.1. 使用symbol定义的属性,是不能通过如下方式拿到的)
- [4.2. 如何拿到symbol的字符串key](#4.2. 如何拿到symbol的字符串key)
Symbol
1. 自ECMAScript 2015起,symbol成为了一种新的原生类型,就像number和string一样。
1.1. symbol类型的值是通过Symbol构造函数创建的。
1.2. 可以传递参做为唯一标识 只支持 string 和 number类型的参数
javascript
复制代码
// 1. 可以传递参做为唯一标识 只支持 string 和 number类型的参数
let sym1: symbol = Symbol()
let sym2: symbol = Symbol('key') // 可选的字符串key
console.log(sym1, sym2)
2. Symbol的值是唯一的。
2.1. Symbol的值是唯一的
2.2. Symbol.for可以获取到相同的值
2.3 Symbol.for和Symbol的区别:for在全局Symbol里面找有没有注册过这个key, 如果有直接拿来用, 没有的话就创建一个
javascript
复制代码
// 2. Symbol的值是唯一的
let sym1: symbol = Symbol(1) // 唯一
let sym2: symbol = Symbol(1) // 唯一
// sym1 === sym2 =>false
// console.log(sym1 === sym2)
// Symbol.for和Symbol的区别:for在全局Symbol里面找有没有注册过这个key, 如果有直接拿来用, 没有的话就创建一个
console.log('Symbol.for===', Symbol.for('小满') === Symbol.for('小满')) // true
3. Symbol的使用场景。
3.1. symbol的key值一样不覆盖对象的属性
javascript
复制代码
// 场景1: symbol的key值一样不覆盖对象的属性
let sym = Symbol()
let obj = {
[sym]: 'value',
[sym1]: 111,
[sym2]: 222
}
console.log(obj) // "value"
console.log(obj[sym]) // "value"
const symbol1 = Symbol('666')
const symbol2 = Symbol('777')
const obj1 = {
[symbol1]: '小满',
[symbol2]: '二蛋',
age: 19,
sex: '女'
}
4. symbol定义属性的获取
4.1. 使用symbol定义的属性,是不能通过如下方式拿到的
javascript
复制代码
// 1 for in 遍历(不能读到symbol属性的)
for (const key in obj1) {
// 注意在console看key,是不是没有遍历到symbol1和symbol2
console.log(key)
}
// 2 Object.keys 遍历(不能读到symbol属性的)
Object.keys(obj1)
console.log(Object.keys(obj1))
// 3 getOwnPropertyNames 遍历
console.log('getOwnPropertyNames=', Object.getOwnPropertyNames(obj1))
// 4 JSON.stringify(不能读到symbol属性的)
console.log(JSON.stringify(obj1))
4.2. 如何拿到symbol的字符串key
Object.getOwnPropertySymbols
es6 的 Reflect - Reflect.ownKeys(obj1)
javascript
复制代码
// 5.如何拿到symbol1和symbol2的字符串key
// 5.1 只能读到symbol属性(拿到具体的symbol 属性,对象中有几个就会拿到几个)
Object.getOwnPropertySymbols(obj1)
console.log(Object.getOwnPropertySymbols(obj1))
// 2 es6 的 Reflect 拿到对象的所有属性
Reflect.ownKeys(obj1)
console.log(Reflect.ownKeys(obj1))
// console.log('symbol1=', symbol1.description)
// console.log('symbol2=', symbol2.description)