当前位置: 首页 > news >正文

JavaScript数据类型- Symbol 详解

文章目录

    • 前言
    • 1.唯一性
    • 2. 描述
    • 3. 作为对象属性键
    • 4. 全局注册
    • 6. 不可变性
    • 7. 隐式转换

前言

Symbol是ES6新增内容,代表创建后独一无二且不可变的数据类型,它主要是为了解决可能出现的全局变量冲突的问题
在JavaScript发展的过程中,其中的ES6带来了一系列的新特性,其中之一就是Symbol。Symbol是一种特殊的原始数据类型,它提供了一种创建全局唯一标识符的方式,这对于避免命名冲突尤其有用。不同于传统的字符串或数字,每个Symbol都是独立且唯一的,即使它们具有相同的描述。这使得Symbol非常适合用于对象属性的键,从而避免了与其他属性键发生冲突的可能性。本文旨在深入探讨Symbol的各个方面,包括它的创建、使用方法以及与其他数据类型的交互方式,帮助更好地理解和利用这一特性。

1.唯一性

每次调用 Symbol() 都会返回一个新的、唯一的 Symbol 值

const sym1 = Symbol();
const sym2 = Symbol();
console.log(sym1 === sym2); // false

2. 描述

可以给 Symbol 提供一个可选的字符串参数作为描述,这有助于调试,但不会影响 Symbol 的唯一性

const sym = Symbol('mySymbol');
console.log(sym.toString()); // "Symbol(mySymbol)"

3. 作为对象属性键

Symbol 可以用作对象属性的键,并且不会与任何字符串键冲突

const key = Symbol('key');
const obj = {[key]: 'value'
};
console.log(obj[key]); // 'value'
console.log(obj['key']); // undefined

4. 全局注册

使用 Symbol.for(key) 可以创建一个全局唯一的 Symbol,如果之前已经存在相同的键,则返回已存在的 Symbol。

const sym1 = Symbol.for('foo');
const sym2 = Symbol.for('foo');
console.log(sym1 === sym2); // true

6. 不可变性

Symbol 是不可变的,一旦创建就无法改变其值。

7. 隐式转换

当尝试将 Symbol 转换成其他类型(如数字或字符串)时,会抛出 TypeError。不过,Symbol 可以通过 .toString() 或 .description 获得其字符串表示形式。

http://www.lryc.cn/news/477986.html

相关文章:

  • WordPress网站添加嵌入B站视频,自适应屏幕大小,取消自动播放
  • 11.6 校内模拟赛总结
  • Redis常用的五大数据类型(列表List,集合set)
  • Ubuntu 20.04 部署向量数据库 Milvus + Attu
  • 实现数传数据转网口(以太网)和遥控器SBUS信号转串口的功能
  • APP 后台广告位配置的关键要素与策略
  • 分布式数据库概述
  • 用通义灵码帮助实现校验bpmn.js当前画布上只能有一个开始节点的功能
  • OKHTTP断点续传
  • 软件测试学习笔记丨Flask操作数据库-ORM
  • ABAP 开发的那些小技巧
  • 电科金仓(人大金仓)更新授权文件(致命错误: XX000: License file expired.)
  • 玩转「HF/魔搭/魔乐」平台
  • 鸿蒙系统的优势 开发 环境搭建 开发小示例
  • python批量合并excel文件
  • AWS S3 JavaScript SDK(v3)常用操作
  • 数据结构——图的基本操作
  • 掌握全球速递:在表格中高效利用国际快递公式查询快递
  • 【MySQL系列】字符集设置
  • Vue2进阶之Vue3高级用法
  • 基于微信的追星小程序+ssm(lw+演示+源码+运行)
  • 【51单片机】串口通信原理 + 使用
  • 优选算法第五讲:位运算模块
  • 【07】Maven项目多环境打包配置
  • 嵌入式Linux入门具备:C语言基础与基本驱动学习(2):Linux GIibc IO基础
  • 【微服务】Docker 容器化
  • [前端] 为网站侧边栏添加搜索引擎模块
  • 解决CORS (跨源资源共享) 错误
  • Redis 实现分布式缓存
  • Chrome与火狐哪个浏览器的移动版本更流畅