15.Symbol类型

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)
相关推荐
二十一_2 小时前
炸了!Claude Code 51万行源码全部泄露,我已经拿到了完整代码
前端·langchain·claude
RePeaT2 小时前
npm 依赖版本号中 `^` 和 `~` 到底有什么区别?
前端·javascript·npm
DanCheOo2 小时前
多模型适配:一套代码接 6 家 AI 厂商
前端·ai编程
米丘2 小时前
Node.js 事件循环
前端·javascript·node.js
Forever7_2 小时前
紧急!Axios 被投毒,3亿项目受到影响!教你怎么自查!
前端·axios
zzialx1232 小时前
HarmonyOS:照片添加多样式的水印信息
前端
前端冒菜师2 小时前
记一次AI全栈开发的过程
前端·ai编程
Giant1002 小时前
深度玩转 Cursor Rules:让 AI 生成的代码 100% 符合团队规范
前端·面试
代码煮茶2 小时前
Vue3 组件通信实战 | 8 种组件通信方式全解析
前端·vue.js