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)
相关推荐
@大迁世界10 分钟前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
千叶风行36 分钟前
Text-to-SQL 技术设计与注意事项
前端·人工智能·后端
软件开发技术深度爱好者42 分钟前
HTML5+JavaScript读取DOCX 文档完整内容
前端·html5
幽络源小助理1 小时前
苹果CMS V10 MXPro V4.5模版下载, 自适应视频主题源码, 幽络源源码
前端·开源·源码·php源码
kyriewen2 小时前
坏了,黑客学会用AI写外挂了
前端·程序员·ai编程
xiangxiongfly9152 小时前
Vue3 根据角色权限动态加载路由
前端·javascript·vue.js·动态加载路由
达达尼昂2 小时前
Claude 多 Agent 系统:从零搭建一个 4 Agent 团队
前端·架构·ai编程
Aolith3 小时前
我是怎么把个人论坛首页性能从80分优化到100分的(附踩坑全记录)
vue.js·性能优化
费曼学习法3 小时前
React 18 并发模式(Concurrent Mode):Fiber 架构的终极进化
javascript·react.js
容智信息3 小时前
AI Agent(智能体)的输出格式应该从 Markdown 转向 HTML吗?
前端·人工智能·rust·编辑器·html·prompt