”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > JS 中的符号和对象♥

JS 中的符号和对象♥

发布于2024-11-08
浏览:210

Symbols and Objects in JS♥

符号数据类型

Symbol 是 JS 中的一种数据类型。它通常用于在 Javascript 中创建唯一键和隐藏对象键。

有两种类型的符号

  1. 本地符号 - 它们未在全局符号注册表中注册,即使具有相同的描述符,值也是唯一的。
  2. 全局符号 - 它们在全局符号注册表中注册,并且值不是唯一的

全局符号注册表:全局符号注册表是存储使用Symbol.for创建的符号的空间。

句法
在下面的示例中,“john”是描述符,key_one 和 key_two 是符号。

const key_one = Symbol("john"); //local symbol
const key_two = Symbol.for("john"); //global symbol
console.log(typeof key_one) // symbol
console.log(typeof key_two); //symbol

主要区别

相同值的描述符在局部符号中不相同

正如我之前所说,即使局部符号中的描述符相同,每个符号也是唯一的。让我们验证一下。

应用程序

const key_one = Symbol("john");
const key_two = Symbol("john");
key_one == key_two // false
key_one === key_two //false

相同值的描述符在全局符号中是相同的

const key_one = Symbol.for("foo");
const key_two = Symbol.for("foo");
console.log(key_one === key_two); //true

关于物体和符号的一些事实

  1. 符号不会转换为字符串。
  2. 您无法使用 for...in 循环访问这两个符号
  3. 即使使用 Object.keys() 属性也无法访问这两个符号
  4. 对象中的每个键都被转换为字符串偶数。
  5. 使用Object.getOwnPropertySymbols()函数可以查看对象的所有符号

应用程序

const zero = Symbol("0");
const temp = {
 0:"zero",
 1:"one",
 [zero]:"zero",
 1.1:"one one",
}
const keys = Object.keys(temp); //["0","1","1.1"]
console.log(temp[1.1]) // one one
console.log(Object.getOwnPropertySymbols(temp)) // [Symbol(0)]

如何在Symbol.for()中获取描述符

使用Symbol.keyFor(symbol)可以获得全局符号的描述符

const key_one = Symbol.for("john")
Symbol.keyFor(key_one) // "john"
typeof Symbol.keyFor(key_one) //string

请在 dev.to 和 linkedin 上支持我? TY?

版本声明 本文转载于:https://dev.to/aryan015/symbols-and-objects-in-js-3ko7?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 保护您的数据:如何创建不可破解的 SQL 和 MySQL 数据库副本
    保护您的数据:如何创建不可破解的 SQL 和 MySQL 数据库副本
    锁定前规划的审慎措施可确保 SQL 或 MySQL 数据库一旦转换为只读状态,即可按预期运行,并且仍可供指定用户组访问。这种远见还保证了数据库在将来需要更新或更改时可以安全地解锁。 将数据库设置为只读有一定的吸引力,这会引起 DBA 的共鸣。就好像数据库已经成熟并准备好走向世界,不受不断更新需求的阻...
    编程 发布于2024-11-08
  • 使用拦截器自定义获取并在 nuxt 3 中登录
    使用拦截器自定义获取并在 nuxt 3 中登录
    如果您使用过 Nuxt,您可能遇到过方便的 useFetch 可组合项: <script setup lang="ts"> const { data, status, error, refresh, clear } = await useFetch('/api/modules') <...
    编程 发布于2024-11-08
  • React源码中MessageChannel的使用
    React源码中MessageChannel的使用
    这篇文章我们分析React源码中MessageChannel的用法。 我们先来了解一下什么是MessageChannel。 消息频道 Channel Messaging API 的 MessageChannel 接口允许我们创建一个新的消息通道并通过它的两个 MessagePort ...
    编程 发布于2024-11-08
  • 如何在CSS中模糊背景图像而不模糊内容?
    如何在CSS中模糊背景图像而不模糊内容?
    CSS 在保持内容清晰度的同时对背景图像进行模糊处理尝试在 CSS 设置中模糊背景图像时,通常会遇到内容(文本或其他元素)也变得模糊的问题。这就是 z-index 和伪元素的概念发挥作用的地方。要模糊背景图像而不影响内容,可以采用以下方法:创建背景容器:将背景图像包含在div或其他容器中,并为其分配...
    编程 发布于2024-11-08
  • 哑的
    哑的
    大家好,我是Misti-sage,DOOF的唯一创造者: 动态的 输出 针对进行了优化 灵活性。 (我是编码新手,所以我的大部分(如果不是全部)DOOF 工作都是由 ChatGPT 协助的。) 我欢迎任何可以帮助改进 DOOF(也称为 Darfensmirg)的人。 <!DOCTYPE htm...
    编程 发布于2024-11-08
  • 为什么 Go 正则表达式 \\b 边界对于拉丁字符会失败?
    为什么 Go 正则表达式 \\b 边界对于拉丁字符会失败?
    \b Go 正则表达式中拉丁字符的边界在 Go 正则表达式的世界中, \b 边界选项有一个轻微的怪癖处理拉丁字符时。当尝试定义包含拉丁字符(例如重音元音和特殊字符)的单词时,就会出现此问题。考虑以下示例,我们希望使用 \b 边界选项来匹配单词“vis”:import ( "fmt&...
    编程 发布于2024-11-08
  • H2 与 HSQLDB:哪种嵌入式数据库最适合我的财务管理应用程序?
    H2 与 HSQLDB:哪种嵌入式数据库最适合我的财务管理应用程序?
    Java 嵌入式数据库比较鉴于有大量可用选项,为您的财务管理应用程序选择嵌入式数据库可能具有挑战性。为了帮助您,让我们根据您的需求比较 H2、HSQLDB、Derby 和 Berkeley DB。H2 与 HSQLDBH2 和 HSQLDB 都提供出色的性能和稳定。 H2以速度着称,而HSQLDB则...
    编程 发布于2024-11-08
  • C 中允许多少级指针间接寻址?
    C 中允许多少级指针间接寻址?
    C 语言中的指针深度:了解级别限制在 C 编程中,变量可以使用指针具有多层间接寻址。这种灵活性允许复杂的数据结构和高效的内存管理。然而,问题出现了:单个变量允许的最大指针级别(称为“*”)是多少?了解指针深度的限制对于有效和安全的编程至关重要。 C 标准定义了允许的指针级别数的下限,但上限是特定于实...
    编程 发布于2024-11-08
  • 光泽和微光让我的心率下降 - 案例研究
    光泽和微光让我的心率下降 - 案例研究
    最近,一位客户联系我,询问其 WordPress 网站上的“财务评估”javascript 应用程序不再工作。它有很多问题,最后,最简单的方法就是重建它。 在此应用程序中,用户可以输入基本的财务和个人信息,应用程序会告诉他们在财务规划方面是否走在正确的道路上。这不是超级复杂的逻辑,但有相当多的逻辑。...
    编程 发布于2024-11-08
  • 案例研究:加权九尾问题
    案例研究:加权九尾问题
    加权九尾问题可以简化为加权最短路径问题。 部分提出了九尾问题并使用 BFS 算法解决了它。本节介绍问题的变体并使用最短路径算法解决它。 九尾问题是找到导致所有硬币面朝下的最少移动次数。每一步都会翻转一枚正面硬币及其相邻硬币。加权九尾问题将翻转次数指定为每次移动的权重。例如,您可以通过翻转第一行中的第...
    编程 发布于2024-11-08
  • 如何在不依赖扩展名的情况下确定文件类型?
    如何在不依赖扩展名的情况下确定文件类型?
    如何在不依赖扩展名的情况下检测文件类型除了检查文件的扩展名之外,确定文件是 mp3 还是图像格式是很有价值的编程中的任务。这是一个不依赖扩展的全面解决方案:PHP >= 5.3:$mimetype = finfo_fopen(fopen($filename, 'r'), FILEINFO_MIME_...
    编程 发布于2024-11-08
  • 变量和文件夹的命名规则是什么?
    变量和文件夹的命名规则是什么?
    การตั้งชื่อสำหรับตัวแปรและโฟลเดอร์ในโปรเจกต์มีความสำคัญมากในการรักษาความอ่านง่ายและความเป็นระเบียบของโค้ด ต่อไปนี้คือลักษณะและกฎทั่วไปในการตั้งชื่อ: ...
    编程 发布于2024-11-08
  • 使用 Python 构建测验应用程序:分步指南
    使用 Python 构建测验应用程序:分步指南
    您是否曾想创建自己的测验应用程序?这是一个有趣的项目,可以帮助您学习编程,同时也可以创造一些有用的东西。在此项目中,我们将逐步介绍如何构建一个包含多项选择题、评分、时间限制和不同主题的简单测验应用程序。 我们的测验应用程序会做什么 我们的测验应用程序将: 提出多项选择题 记录分数 ...
    编程 发布于2024-11-08
  • 如何跨多个浏览器执行WebUI功能文件
    如何跨多个浏览器执行WebUI功能文件
    跨多个浏览器执行 WebUI 功能文件并行测试和分布式测试技术提供了跨各种浏览器执行 WebUI 功能文件的能力。在本文中,我们将探讨如何在 Karate 和 Zalenium 中使用这些方法。使用 Parallel RunnerKarate 中的并行运行器允许您执行并行的示例表。要利用此功能针对多...
    编程 发布于2024-11-08
  • PHP 中的 URL 缩短有哈希替代方法吗?
    PHP 中的 URL 缩短有哈希替代方法吗?
    URL 缩短的散列的替代方案正在寻求一种 PHP 解决方案来创建简洁的散列,就像 URL 缩短服务(如 TinyURL)所使用的那样?虽然可能会想到散列,但此响应揭示了一种不同的方法。TinyURL 不依赖散列,而是利用 Base 36 整数(甚至包括大写和小写字母的 Base 62)来识别目标记录...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3