ES6 新特性:Symbol 概述

ECMAScript 6(ES6)引入了一种新的原始数据类型:Symbol。Symbol 是一种唯一且不可变的数据类型,主要用于作为对象属性的标识符。这篇文章将为你提供一个关于 Symbol 的概述,包括它的创建、应用和一些特殊的内置 Symbol。

创建 Symbol

Symbol 通过调用 Symbol() 函数创建,每个 Symbol 值都是独一无二的。

javascript 复制代码
let symbol1 = Symbol();
let symbol2 = Symbol('description');
let symbol3 = Symbol('description');

console.log(symbol1 === symbol2); // 输出: false
console.log(symbol2 === symbol3); // 输出: false

即使两个 Symbol 有相同的描述,它们也是不同的。

使用 Symbol

Symbol 最常见的用途是作为对象属性的键。

作为属性键

javascript 复制代码
let mySymbol = Symbol();
let obj = {
    [mySymbol]: "value"
};

console.log(obj[mySymbol]); // 输出: "value"

使用 Symbol.for() 和 Symbol.keyFor()

Symbol.for() 方法接受一个字符串作为参数,然后搜索有没有以该参数作为名称的 Symbol 值。如果有,就返回这个 Symbol 值,否则创建并返回一个新的 Symbol 值。

javascript 复制代码
let sym1 = Symbol.for("key");
let sym2 = Symbol.for("key");

console.log(sym1 === sym2); // 输出: true

Symbol.keyFor() 方法返回一个已登记的 Symbol 类型值的 key。

javascript 复制代码
let sym = Symbol.for("key");
console.log(Symbol.keyFor(sym)); // 输出: "key"

内置的 Symbol

ES6 提供了一些内置的 Symbol 值,它们代表了语言内部的一些方法。

常见的内置 Symbol

  • Symbol.iterator:对象实现该属性后,对象可被 for...of 循环遍历。
  • Symbol.match:指定了匹配的是正则表达式的方法。
  • Symbol.toPrimitive:指定对象转换为原始类型值的方法。
  • Symbol.toStringTag:在对象上调用 Object.prototype.toString 方法时,会出现在返回的字符串中。

注意事项

  • Symbol 不是构造函数,所以不能使用 new
  • Symbol 可以转换为字符串和布尔类型,但不能转换为数值。
  • 使用 Symbol 作为对象属性时,这个属性将不会出现在传统的遍历中,如 for...in 循环或 Object.keys() 方法。

ES6 中的 Symbol 提供了一种独特的方式来创建对象的私有成员,同时也被用于扩展对象的功能,而不影响现有的代码结构。了解和使用 Symbol 可以帮助你更好地利用 JavaScript 语言的特性。

相关推荐
加减法原则7 小时前
Vue3 组合式函数:让你的代码复用如丝般顺滑
前端·vue.js
天若有情6738 小时前
React、Vue、Angular的性能优化与源码解析概述
vue.js·react.js·angular.js
草巾冒小子9 小时前
vue3实战:.ts文件中的interface定义与抛出、其他文件的调用方式
前端·javascript·vue.js
eggcode9 小时前
Vue+Openlayers加载OSM、加载天地图
vue.js·openlayers·webgis
武昌库里写JAVA12 小时前
vue3面试题(个人笔记)
java·vue.js·spring boot·学习·课程设计
lalalalalalalala13 小时前
开箱即用的 Vue3 无限平滑滚动组件
前端·vue.js
前端Hardy13 小时前
8个你必须掌握的「Vue」实用技巧
前端·javascript·vue.js
久爱@勿忘14 小时前
第二章:创建登录页面
前端·vue.js·elementplus
Jinxiansen021114 小时前
Vue 3 中父子组件双向绑定的 4 种方式
javascript·vue.js·ecmascript
木依14 小时前
Vue3 Element plus table有fixed列时错行
javascript·vue.js·elementui