Symbol是什么?JS中Symbol用法详解
时间:2025-12-27 20:51:56 412浏览 收藏
golang学习网今天将给大家带来《Symbol是什么?JS中Symbol的用途解析》,感兴趣的朋友请继续看下去吧!以下内容将会涉及到等等知识点,如果你是正在学习文章或者已经是大佬级别了,都非常欢迎也希望大家都能给我建议评论哈~希望能帮助到大家!
Symbol 是 JavaScript 中用于创建唯一不可变值的原始类型,主要解决对象属性名冲突问题;其核心特性为唯一性、私密性及预定义符号对对象行为的定制能力。

Symbol 是 JavaScript 中一种原始数据类型,用来创建唯一且不可变的值,主要解决对象属性名冲突问题。
Symbol 的核心特点:唯一性与私密性
每次调用 Symbol() 都会返回一个全新的、与其他所有 Symbol 值不相等的值(即使描述相同):
Symbol('a') !== Symbol('a')—— 两个同名 Symbol 依然不等Symbol.for('a') === Symbol.for('a')—— 全局注册表中才可复用(需主动使用Symbol.for)- Symbol 值不能参与运算或隐式转换,
String(sym)或sym.toString()才能转为字符串
作为对象属性键:避免命名冲突
把 Symbol 当作属性名,能防止意外覆盖或被枚举到:
- 对象中用
obj[mySym] = 'secret'定义属性,该属性不会出现在for...in、Object.keys()、JSON.stringify()中 - 但可通过
Object.getOwnPropertySymbols(obj)获取所有 Symbol 属性 - 适合实现“弱公开”内部字段,比如类的私有状态标识:
class Counter { constructor() { this[Counter._count] = 0; } }
预定义 Symbol(Well-known Symbols):定制对象行为
ES6 提供一组内置 Symbol,用于自定义对象在特定场景下的表现:
Symbol.iterator:让对象支持for...of和扩展运算符(如实现自定义迭代器)Symbol.toStringTag:影响Object.prototype.toString.call(obj)的返回结果(如class A { [Symbol.toStringTag] = 'MyClass'; }→[object MyClass])Symbol.hasInstance:重写instanceof的判断逻辑Symbol.toPrimitive:控制对象转原始值时的行为(如 +、==、String() 等场景)
不是真正的“私有”,但提供了可控的封装边界
Symbol 属性不是完全隐藏的 —— 它们可被反射 API(如 getOwnPropertySymbols)发现,也不阻止调试或动态访问。但它明确传递了“这个属性是内部用途”的意图,比用下划线约定更可靠、更规范。
基本上就这些。Symbol 不复杂,但容易忽略它在设计健壮 API 和避免污染时的实际价值。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
相关阅读
更多>
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
250 收藏
-
204 收藏
-
157 收藏
-
465 收藏
-
394 收藏
-
434 收藏
-
457 收藏
-
311 收藏
-
388 收藏
-
326 收藏
-
167 收藏
-
353 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习