Symbol 类型必知必会

fileOf7174.png

一. Symbol的概念

SymbolJavaScript 中的一种新的基本数据类型,引入自 ECMAScript 6(ES6)标准。它是一种不可变且唯一的数据类型,可以用来创建独一无二的键(key)。

Symbol 的创建方式是通过调用全局的 Symbol() 函数来生成。每个通过 Symbol() 创建的 Symbol 值都是独一无二的,即使它们的描述符相同也不相等。

Symbol 主要用于对象属性的唯一性标识。在对象中,Symbol 可以作为属性名,用来定义对象的非字符串类型的属性。由于每个 Symbol 都是唯一的,因此可以确保属性名的唯一性,避免属性名冲突的问题。

Symbol 还有一些内置的属性,比如 Symbol.iteratorSymbol.hasInstance 等,在某些情况下可以用来自定义对象的行为。

总而言之,SymbolJavaScript 中一种用于创建独一无二键的基本数据类型,可用于定义对象的非字符串属性名,解决属性名冲突的问题。

二. Symbol的使用方式

Symbol 的使用可以通过以下几个步骤进行:

1. 创建 Symbol:
const mySymbol = Symbol();
2. 使用 Symbol 作为对象属性名:
const obj = {};
const mySymbol = Symbol();
obj[mySymbol] = 'Symbol属性';
console.log(obj[mySymbol]); // 输出:Symbol属性
3. Symbol 的描述符:
const mySymbol = Symbol('描述符');
console.log(mySymbol.toString()); // 输出:Symbol(描述符)
4. Symbol 的内置属性:
const mySymbol = Symbol.iterator;
const arr = [1, 2, 3];
const iterator = arr[mySymbol]();
console.log(iterator.next()); // 输出:{ value: 1, done: false }

需要注意的是,Symbol 作为属性名时,无法使用点运算符 (.) 而必须使用方括号 ([]) 来访问。

Symbol 的主要作用是确保属性名的唯一性,避免属性名冲突的问题,以及在某些情况下可以自定义对象的行为。例如,可以使用 Symbol.iterator 创建一个自定义迭代器,通过遍历符号属性来处理对象的迭代。

除了以上示例,Symbol 还可以与其他 JavaScript 特性如迭代器、生成器、反射等一起使用,提供更强大的编程能力。

三. Symbol的使用场景

Symbol的使用场景有很多,尤其用于创建独一无二键的基本数据类型,解决属性名冲突时使用。下面列举几个常见的例子:

1. 属性名冲突解决:使用 Symbol 作为对象属性名,可以确保属性名的唯一性,避免属性名冲突的问题。
const name = Symbol('name');
const age = Symbol('age');const person = {[name]: 'John',[age]: 30
};console.log(person[name]); // 输出:John
console.log(person[age]); // 输出:30
2. 迭代器和可迭代对象:通过使用内置的 Symbol.iterator 属性,可以为对象创建自定义的迭代器,实现可迭代对象的遍历。
const myIterable = {};
myIterable[Symbol.iterator] = function* () {yield 1;yield 2;yield 3;
};for (const value of myIterable) {console.log(value); // 输出:1 2 3
}
3. 隐藏属性:使用 Symbol 作为属性名,可以隐藏属性,使其不容易被意外访问到。
const secretKey = Symbol('secretKey');const obj = {[secretKey]: 'abcdefg'
};console.log(obj[secretKey]); // 输出:abcdefg
4. 自定义对象的行为:通过自定义 Symbol 属性,可以自定义对象的一些行为,如迭代器、比较、字符串转换等。
const comparator = Symbol('comparator');class Person {constructor(name) {this.name = name;}[comparator](other) {return this.name.length - other.name.length;}
}const person1 = new Person('John');
const person2 = new Person('Jane');console.log(person1[comparator](person2)); // 输出:-1

这些只是 Symbol 的一些常见使用场景,Symbol 还可以与其他 JavaScript 特性相结合,扩展出更丰富的应用场景。

四.总结

使用Symbol具有以下的优势:

1. 属性名的唯一性:

Symbol 可以确保属性名的唯一性,避免属性名冲突的问题。即使多个 Symbol 值使用相同的描述符,它们依然是不同的属性名。

2. 防止属性被意外访问:

使用 Symbol 作为属性名,可以隐藏属性,使其不容易被意外访问到。这有助于在对象中定义私有属性或内部使用的属性。

3. 扩展对象的功能:

通过自定义 Symbol 属性,可以为对象添加自定义行为,如迭代器、比较器等。这样,我们可以更灵活地扩展对象的功能,使其具备更多特定的行为。

4. 安全性提升:

Symbol 的属性名不会被常规的属性遍历方法(如 for...in 循环)访问到,可以在一定程度上提升对象的安全性,防止属性被意外修改。

使用Symbol的缺点:

1. 无法遍历:

Symbol 作为属性名时,无法通过常规的属性遍历方法(如 for...in 循环)获取到。如果需要遍历对象的属性,就不能使用 Symbol 作为属性名。

2. 内存泄漏:

由于 Symbol 创建的属性是唯一的,一旦创建后就无法被销毁或被垃圾回收机制回收。如果大量使用 Symbol 创建属性,可能会造成内存泄漏的问题。

3. 可调试性差:

Symbol 属性名在控制台输出时,没有明确的标识,不容易调试和查看对象的具体属性。

4. 不可序列化:

Symbol 值不能被 JSON.stringify() 序列化,也不能作为对象的键值传递给其他线程或进程。

总结

通过学习Symbol,我们了解到虽然 Symbol 有一些缺点,但在合适的场景下,其独特的特性和优势仍然使其成为一个有价值的选择。为了充分利用 Symbol,需要在实际应用中权衡其优缺点,根据需求进行合理使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/771550.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

测试开发工程师(QA)职业到底需要干些什么?part4:安全QA

安全测试开发QA工作的主要目标是确保软件、应用程序或系统在安全方面的健壮性和可靠性。以下是安全测试开发QA工作中的一些常见任务和职责: 安全测试计划和策略:安全测试开发QA团队负责制定全面的安全测试计划和策略。他们会评估应用程序或系统的安全需求…

【优选算法】专题1 -- 双指针 -- 复写0

前言: 补充一下前文没有写到的双指针入门知识:专题1 -- 双指针 -- 移动零 目录 基础入门知识: 1. 复写零(easy) 1. 题⽬链接:1089.复习0 - 力扣(LeetCode) 2. 题⽬描述&#xff…

数据容器-dict以及总结-Python

师从黑马程序员 字典的定义 同样使用{},不过存储的元素是以个个的:键值对,如下语法: #定义字典 my_dict1{"王力宏":99,"周杰伦":88,"林俊杰":77} #定义空字典 my_dict2{} my_dict3dict() print(f"字典1…

springboot 将manage关闭。

这是SpringBoot自带的接口,会将所有的接口暴露在外面。所以我们上生产环境,需要将这个接口给关闭。 默认是 management.endpoints.web.exposure.include* 只需将配置文件改成下面,Springboot自带的接口就会关闭。 management.endpoints.…

【物联网开源平台】tingsboard二次开发

别看这篇了,这篇就当我的一个记录,我有空我再写过一篇,编译的时候出现了一个错误,然后我针对那一个错误执行了一个命令,出现了绿色的succes,我就以为整个tingsboard项目编译成功了,后面发现的时候&#xff…

记录微信小程序云开发的增删改查

目录 一、准备工作 1、创建集合添加数据 2、设置数据权限 3、小程序连接数据库 二、增删改查 1.查 1、查询单集合所有数据 2、条件查询 1、直接:相当于等于 2、调用指令 3、查询单条(根据id查询) 2.增 3.改 4.删 一、准备工作 1、创建集合添…

力扣---最长公共子序列---二维动态规划

思想: 定义g[i][j]:text1的前i位和text2的前j位的最长公共子序列长度。递推公式:如果text[i]text[j],那么只需要看g[i-1][j-1]即可,此时g[i][j]g[i-1][j-1]1。如果text[i]!text[j],那么g[i][j]max(g[i-1][j…

【研发管理】研发管理规范

研发管理规范 目的定义工作职责产品经理项目经理运维负责人研发负责人研发工程师 基本原则研发过程描述需求分析分析设计研发实现测试验收发布上线线上监控 目的 软件研发相关管理,有效控制技术风险,提高研发和运行质量 定义 包括需求分析、分析设计…

【C】盛最多水的容器(双指针)

盛最多水的容器 原题目链接:点击跳转 给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和(i, height[i]) 。 找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可以储存的最大水量。 说…

小学生古诗文大会往届真题测一测(来自主办方)和非常详细的解析

新学期开学一眨眼已经过了一个多月了,有家长朋友开始关心2024年上海市小学生古诗文大会什么时候开始?如何准备小学生古诗文大会?如何激发孩子学习古诗词的兴趣?如何提高小学古诗词和古诗文大会的学习成绩?... 最近&…

基于SpringBoot+Vue共享汽车管理系统(源码+部署说明+演示视频+源码介绍)

您好,我是码农飞哥(wei158556),感谢您阅读本文,欢迎一键三连哦。💪🏻 1. Python基础专栏,基础知识一网打尽,9.9元买不了吃亏,买不了上当。 Python从入门到精通…

3.25C++

定义自己的命名空间&#xff0c;其中有string类型的变量&#xff0c;再定义两个函数&#xff0c;一个函数完成字符串的输入&#xff0c;一个函数完成求字符串长度&#xff0c;再定义一个全局函数完成对该字符串的反转 #include <iostream> #include <cstring> usi…

网络基础二——序列化与反序列化

1、应用层 我们程序员写的一个个解决我们实际问题&#xff0c;满足我们日常需求的网络程序&#xff0c;都是在应用层。 2、再谈“协议” 协议是一种 " 约定 "。 socket api 的接口 , 在读写数据时 , 都是按 " 字符串 " 的方式来发送接收的 . 如果我们…

c++模拟银行家算法

在复习408时,使用代码模拟能够加深对知识点的理解 1.银行家算法介绍 银行家算法是迪杰斯特拉发明的死锁避免的算法。找到合理的资源分配序列保证各进程的正常推进是银行家算法的核心。 2.自定义类以及成员变量和成员函数说明 进程类 //进程类 class Process; //资源最大需求…

FPGA之状态机学习

作为一名逻辑工程师&#xff0c;掌握和应用状态机设计是必不可少的。能够灵活的应用状态机是对逻辑工程师最基本的要求&#xff0c;状态机设计的好坏能够直接影响到设计系统的稳定性&#xff0c;所以学会状态机是非常的重要。 1.状态机的概念 状态机通过不同的状态迁移来完成特…

【C语言】Infiniband驱动__mlx4_init_one函数

一、注释 Linux内核驱动程序中的部分&#xff0c;属于Mellanox网卡驱动mlx4的初始化过程。 // Mellanox 以太网驱动主程序代码 static int __mlx4_init_one(struct pci_dev *pdev, int pci_dev_data,struct mlx4_priv *priv) {int err; // 错误码变量int nvfs[MLX4_MAX_PORTS…

【SSH配置公钥私钥免密登录】

SSH配置公钥私钥免密登录 SSH的安全机制一、修改远程主机ssh设置二、在windows客户端生成公钥私钥文件三、将客户端公钥追加到远程主机 .ssh/authorized_keys中参考链接 SSH的安全机制 SSH之所以能够保证安全&#xff0c;原因在于它采用了非对称加密技术(RSA)加密了所有传输的…

机载激光雷达标定板提高测量精度

机载激光雷达系统标定板&#xff08;LiDAR&#xff09;是一种高精度的遥感技术&#xff0c;它通过发射激光脉冲并接收反射回来的光波来测量目标物体的距离。这种技术在测量地形、建筑物、植被等方面有着广泛的应用。为了确保机载激光雷达系统的数据准确性和可靠性&#xff0c;需…

An Experimental Study of State-of-the-Art Entity Alignment Approaches论文阅读

最先进的实体对齐方法的实验研究综述 Title: An Experimental Study of State-of-the-Art Entity Alignment Approaches 日期: 2022 发表单位: IEEE github: https://github.com/DexterZeng/EAE 原文地址: https://ieeexplore.ieee.org/stamp/stamp.jsp?arnumber9174835 概括…

flutter 弹窗之系列二

自定义弹窗&#xff08;含底部抽屉&#xff09;Dialog class MyHomePage extends StatefulWidget {const MyHomePage({super.key, required this.title});final String title;overrideState<MyHomePage> createState() > _MyHomePageState(); }class _MyHomePageState…