symbol 是一个内置对象,其构造函数返回一个 symbol 基元 — 也称为 symbol 值 或只是一个 symbol — 保证是唯一的。符号通常用于向对象添加唯一的属性键,这些属性键不会与任何其他代码可能添加到该对象的键发生冲突,并且对于其他代码通常用于访问该对象的任何机制都是隐藏的。这实现了一种弱封装形式,或者一种弱形式的信息隐藏。
示例:使用符号作为唯一属性键
javascriptcopy code// create unique symbolsconst id = symbol('id');const name = symbol('name');// create an object with symbol-based propertiesconst user = { [id]: 101, [name]: 'alice', age: 25};// access the symbol propertiesconsole.log(user[id]); // 101console.log(user[name]); // "alice"// add another property using a symbolconst email = symbol('email');user[email] = 'alice@example.com';console.log(user[email]); // "alice@example.com"// symbols are not enumerable in for...in loops or object.keysfor (const key in user) { console.log(key); // only "age" is logged}console.log(object.keys(user)); // ["age"]// you can still access all properties if you know the symbol keysconsole.log(object.getownpropertysymbols(user)); // [symbol(id), symbol(name), symbol(email)]
登录后复制
示例:使用 symbol.iterator 使对象可迭代
javascriptcopy codeconst collection = { items: ['apple', 'banana', 'cherry'], [symbol.iterator]() { let index = 0; const items = this.items; return { next() { if (index < items.length) { return { value: items[index++], done: false }; } else { return { done: true }; } } }; }};// iterate over the objectfor (const item of collection) { console.log(item);}// output:// apple// banana// cherry
登录后复制
此示例展示了 symbol.iterator 如何允许使用 for…of 迭代自定义对象。
流行的 npm 库中可用的符号:
示例:在流行的 npm 库中使用符号
symbol 使用的一个著名示例是 express.js 框架,这是一个广泛使用的 node.js web 应用程序框架。在 express.js 中,symbol 用于定义唯一的属性键,防止与用户定义的属性发生潜在冲突。
立即学习“Java免费学习笔记(深入)”;
来自 express.js 的代码片段:
javascriptCopy code// In Express.js, a symbol is used to define a unique property keyconst app = express();app[Symbol('router')] = router;
登录后复制
在此代码片段中,symbol(‘router’) 创建一个唯一的符号,用作应用程序对象的属性键。这种方法确保路由器属性是独特的,并且不会干扰可能添加到应用程序对象的其他属性。
在库中使用符号的好处:
唯一性:符号保证属性键是唯一的,降低意外覆盖的风险。不变性:一旦创建,符号就无法更改,提供稳定的标识符。不可枚举性: 由符号键控的属性在循环中不可枚举,这对于不应公开的内部属性可能是有益的。
以上就是Javascript 中的符号及其示例的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2648149.html