成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

ES6 中的 Symbol 類型在實(shí)際開發(fā)中用得多嗎?

開發(fā) 前端
JavaScript 中的 Array、Set、Map 數(shù)據(jù)類型都可被 for...of 所遍歷。如果面試官說:“實(shí)現(xiàn)一個(gè)可以被 for...of 所遍歷的對(duì)象” 這個(gè)該怎么實(shí)現(xiàn)呢?

知乎上看到的一個(gè)問題:“ES6 中的 symbol 類型在實(shí)際開發(fā)中用得多嗎?”,以前在學(xué)習(xí) ES6 時(shí)也有此疑問,這個(gè) Symbol 是干嘛的?有什么應(yīng)用場(chǎng)景?

Symbol 在實(shí)際開發(fā)中用的不多,在看一些類庫(kù)的實(shí)現(xiàn)時(shí)有看到相關(guān)使用,下面分享下關(guān)于 Symbol 的幾個(gè)使用場(chǎng)景。

做為私有屬性

使用 Symbol 做為私有屬性,最早知道這個(gè)是在 Egg 源碼中學(xué)習(xí)到的,看一段相關(guān)的代碼片段:

// https://github.com/eggjs/egg/blob/3.0.0/lib/core/base_context_logger.js#L22
const CALL = Symbol('BaseContextLogger#call');
class BaseContextLogger {
[CALL](method, args) {
// ...
this.ctx.logger[method](...args);
}
}

在 JavaScript 中為了實(shí)現(xiàn)私有屬性,之前常用的一種方式是命名規(guī)范約定,方法名以 _ 開始。

Symbol 出現(xiàn)之后看到的一個(gè)相對(duì)較多的場(chǎng)景是用它來模式私有屬性、方法。這對(duì)一些 for...in、Object.getOwnPropertyNames() 操作是可以隱藏掉這些屬性,但是 ES6 中的 Symbol 和強(qiáng)類型語言中的 private 相比并不完全是私有的,仍然能通過 Object.getOwnPropertySymbols()、Reflect.ownKeys() 操作枚舉到這些屬性進(jìn)行訪問。

鉤子函數(shù) - 自定義格式輸出

使用 MongoDB Node.js 驅(qū)動(dòng)程序生成一個(gè) id,當(dāng)執(zhí)行 ObjectId()或 new ObjectId() 時(shí)總會(huì)按照固定格式輸出,如下所示:

new ObjectId("632c6d93d65f74baeb22a2c9")

沒了解實(shí)現(xiàn)之前,看起來總歸是有些神秘的,如果自己寫一個(gè)類并實(shí)現(xiàn)自定義輸出信息該怎么做呢?帶著好奇之心看了下源碼實(shí)現(xiàn):

// https://github.com/mongodb/js-bson/blob/v4.4.0/src/objectid.ts#L343
class ObjectId {
toHexString(): string {
const hexString = this.id.toString('hex');
return hexString;
}

[Symbol.for('nodejs.util.inspect.custom')](): string {
return this.inspect();
}

inspect(): string {
return `new ObjectId("${this.toHexString()}")`;
}
}

Symbol.for(str) 是新建一個(gè)以該字符串為名稱的值,并注冊(cè)到全局,如果已注冊(cè)過,就直接返回。與 Symbol() 區(qū)別簡(jiǎn)單理解是,Symbol() 調(diào)用 100 次會(huì)返回 100 個(gè)不同 Symbol 值,Symbol.for(str) 調(diào)用 100 次返回的 Symbol 值都是相同的。

Node.js util 模塊實(shí)現(xiàn)了 util.inspect.custom 方法用于聲明自定義檢查函數(shù),這里個(gè)人理解更像一個(gè)鉤子函數(shù),在 https://github.com/nodejs/node/issues/20821 PR 中已支持將 util.inspect.custom 做為公共符號(hào),實(shí)現(xiàn)了不用加載 util 模塊就可在任何地方使用它,這里用的就是 Symbol.for()。

面試官:實(shí)現(xiàn)一個(gè)可遍歷對(duì)象

JavaScript 中的 Array、Set、Map 數(shù)據(jù)類型都可被 for...of 所遍歷。如果面試官說:“實(shí)現(xiàn)一個(gè)可以被 for...of 所遍歷的對(duì)象” 這個(gè)該怎么實(shí)現(xiàn)呢?

Symbol 提供了 Symbol.iterator 方法,該方法返回一個(gè)迭代器對(duì)象,目前 Array、Set、Map 這些數(shù)據(jù)結(jié)構(gòu)默認(rèn)具有 Symbol.iterator 屬性,而對(duì)象 Object 是沒有的,如下所示:

console.log([][Symbol.iterator]()); // Object [Array Iterator] {}
console.log((new Map())[Symbol.iterator]()); // [Map Entries] { }
console.log((new Set())[Symbol.iterator]()); // [Set Iterator] { }
console.log({}[Symbol.iterator]); // undefined

Symbol.iterator  是迭代協(xié)議標(biāo)準(zhǔn)中的一部分:可迭代器協(xié)議,它定義了哪些值可以被遍歷到。要成為可迭代器對(duì)象,必須實(shí)現(xiàn) @@iterator 方法,可通過常量 Symbol.iterator 訪問(到這里是不是發(fā)現(xiàn),原來常使用的 Array 類型竟和 Symbol 也有聯(lián)系啊

迭代協(xié)議標(biāo)準(zhǔn)的另一部分是:迭代器協(xié)議 ,它定義了產(chǎn)生一系列值的的標(biāo)準(zhǔn)方式。通過定義 next() 方法實(shí)現(xiàn),這里不做詳細(xì)闡述,參見文檔。

了解了  Symbol.iterator 和迭代協(xié)議規(guī)則實(shí)現(xiàn)一個(gè)可被遍歷的對(duì)象并不難。

const range = {
start: 0,
end: 3,
[Symbol.iterator]: function() { return this },
next: function() {
if (this.start > this.end) {
return { value: undefined, done: true }
}

return { value: this.start++, done: false }
}
}

for (const id of range) {
console.log(id); // 0,1,2,3
}

除了 Symbol.iterator 還有 Symbol.asyncIterator,這個(gè)在 Node.js 后端中有一些使用場(chǎng)景。

責(zé)任編輯:武曉燕 來源: 編程界
相關(guān)推薦

2020-12-02 06:11:02

JS ES6方法

2020-03-04 17:38:31

瀏覽器程序員CSS

2021-01-27 07:51:41

JSES6元素

2022-07-26 09:02:15

ES6ES13ECMAScript

2010-10-20 16:43:11

SQL Server管

2022-06-01 09:06:58

ES6數(shù)組函數(shù)

2021-08-16 07:05:58

ES6Promise開發(fā)語言

2020-07-01 07:58:20

ES6JavaScript開發(fā)

2017-08-31 14:25:34

前端JavascriptES6

2018-11-06 10:51:07

Redis開發(fā)存儲(chǔ)系統(tǒng)

2020-11-16 08:10:04

ES6迭代器JavaScript

2021-07-30 07:10:07

ES6函數(shù)參數(shù)

2024-06-26 08:18:08

ES6模板字符串

2023-03-01 15:39:50

JavaScrip對(duì)象屬性ES6

2023-05-28 23:49:38

JavaScrip開發(fā)

2021-07-16 07:26:48

ES6javascript開發(fā)語言

2023-11-23 10:21:11

ECMAScriptJavaScript

2017-10-09 18:21:20

JavaScriptES6ES8

2020-10-22 10:55:55

數(shù)據(jù)結(jié)構(gòu)ES6前端

2021-01-21 05:46:22

JavaLambda開發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 日本久久黄色 | 天天干.com| 天天操 夜夜操 | 欧美一区免费 | 国产精品久久国产精品 | 精品亚洲永久免费精品 | 国产黄视频在线播放 | 亚洲人人| 国产一区二区三区在线视频 | a级片在线 | 久久99精品久久久久蜜桃tv | 亚洲社区在线 | 久久久精品一区二区三区 | 国产精品一区二区三区四区 | 91av在线电影 | 欧美老少妇一级特黄一片 | 久久中文视频 | 精品国产欧美一区二区三区不卡 | 在线观看国产网站 | 亚洲精品久久久久久久久久久久久 | 国产免费一区二区 | 亚洲精品综合 | 成人在线小视频 | 97碰碰碰| 精品视频一区二区 | 欧美一区二区另类 | 久久国产精品一区二区 | 天天色综| 99在线免费视频 | 欧美日韩精品在线一区 | 国产传媒视频在线观看 | 午夜精品一区二区三区在线视频 | 国产视频久久久 | 国产成人免费网站 | 精品久久久久久久久久 | 3级毛片 | 精品久久精品 | 国产成人免费视频网站视频社区 | 久久久久久久亚洲精品 | 黄视频网站免费观看 | 国精产品一品二品国精在线观看 |