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)
相关推荐
IT_陈寒32 分钟前
React状态更新那点事儿,我掉坑里爬了半天
前端·人工智能·后端
cwxcc35 分钟前
Google Core Web Vitals(核心网页指标)
前端·性能优化
|晴 天|1 小时前
Vue 3 + LocalStorage 实现博客游戏化系统:成就墙、每日签到、积分商城
前端·vue.js·游戏
逾明2 小时前
Claude Code及Codex的MCP安装和Mastergo MCP的使用
前端·mcp
LovroMance2 小时前
如何进行组件封装
前端
難釋懷2 小时前
Redis服务器端优化-慢查询优化
前端·redis·bootstrap
sghuter2 小时前
Chrome如何重塑Web标准未来
前端·chrome
渣渣xiong2 小时前
从零开始:前端转型AI agent直到就业第十四天-第十七天
前端·人工智能
changshuaihua0012 小时前
React 入门
前端·javascript·react.js
兰为鹏2 小时前
做前端需求总结出的非常好用的skill
前端