色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

詳解JavaScript私有類字段和TypeScript私有修飾符

瀏覽:3日期:2023-06-05 13:34:29
JavaScript私有類字段和隱私需求

在過去,JavaScript 沒有保護(hù)變量不受訪問的原生機(jī)制,當(dāng)然除非是典型閉包。

閉包是 JavaScript 中許多類似于私有模式(如流行的模塊模式)的基礎(chǔ)。但是,近年來 ECMAScript 2015 類被使用后,開發(fā)人員感到需要對類成員的隱私進(jìn)行更多控制。

類字段提案(在撰寫本文時處于第 3 階段)試圖通過引入私有類字段來解決問題。

讓我們看看它們是什么樣子的。

一個 JavaScript 私有類字段的例子

這是一個帶有私有字段的 JavaScript 類,請注意,與“公有”成員不同,每個私有字段必須在訪問前進(jìn)行聲明:

class Person { #age; #name; #surname; constructor(name, surname, age) { this.#name = name; this.#surname = surname; this.#age = age; } getFullName() { return `${this.#name} + ${this.#surname}`; }}

無法從類的外部訪問私有類字段:

class Person { #age; #name; #surname; constructor(name, surname, age) { this.#name = name; this.#surname = surname; this.#age = age; } getFullName() { return `${this.#name} + ${this.#surname}`; }}const marta = new Person('Marta', 'Cantrell', 33);console.log(marta.#age); // SyntaxError

這是真正的“隱私”。如果你會一點(diǎn) TypeScript,可能會問“原生”私有字段與TypeScript 中的 private 修飾符有什么共同點(diǎn)。

好吧,答案是:沒有。但是為什么?

TypeScript 中的 private 修飾符

有著傳統(tǒng)編程語言背景的開發(fā)人員應(yīng)該熟悉 TypeScript 中的 private 修飾符。簡而言之,此關(guān)鍵字的目的是拒絕從類的外部訪問類成員。

但是請不要忘記,TypeScript 是處于 JavaScript 之上的一層,并且 TypeScript 編譯器應(yīng)該剝離所有花里胡哨的 TypeScript 注釋,包括private。

這意味著下面的類做不到你想要的工作:

class Person { private age: number; private name: string; private surname: string; constructor(name: string, surname: string, age: number) { this.name = name; this.surname = surname; this.age = age; } getFullName() { return `${this.name} + ${this.surname}`; }}const liz = new Person('Liz', 'Cantrill', 31);// @ts-ignoreconsole.log(liz.age);

如果沒有//@ts-ignore,在訪問liz.age時僅會在 TypeScript中引發(fā)錯誤,但是在編譯之后,你將會得到下面的 JavaScript代碼:

'use strict';var Person = /** @class */ (function () { function Person(name, surname, age) {this.name = name;this.surname = surname;this.age = age; } Person.prototype.getFullName = function () {return this.name + ' + ' + this.surname; }; return Person;}());var liz = new Person('Liz', 'Cantrill', 31);console.log(liz.age); // 31

與預(yù)期的一樣,我們可以從控制臺輸出liz.age。這里的主要觀點(diǎn)是 TypeScript 中的 private 不是那么私有,并且僅在 TypeScript 級別才感到方便,而不是“真正的隱私”。

接下來我們開始討論:TypeScript 中的“原生”私有類字段。

TypeScript 中的私有類字段

TypeScript 3.8 將支持 ECMAScript 私有字段,千萬別和TypeScript private 修飾符混淆。

這是在 TypeScript 中具有私有類字段的類:

class Person { #age: number; #name: string; #surname: string; constructor(name:string, surname:string, age:number) {this.#name = name;this.#surname = surname;this.#age = age; } getFullName() {return `${this.#name} + ${this.#surname}`; }}

除了類型注釋外,與原生 JavaScript 沒什么不同。無法從外部訪問成員。但是 TypeScript 中私有字段的真正問題在于它們在后臺使用了 WeakMap。

要編譯此代碼,我們需要調(diào)整 tsconfig.json 中的目標(biāo)編譯版本,該版本最低必須是ECMAScript 2015:

{ 'compilerOptions': { 'target': 'es2015', 'strict': true, 'lib': ['dom','es2015'] }}

這可能會出現(xiàn)問題,具體取決于目標(biāo)瀏覽器,除非你打算為 WeakMap 提供polyfill,否則,如果只是為了編寫精美的新語法,工作量就變得太多了。

JavaScript 中總是存在這種緊張關(guān)系,你確實(shí)想使用新語法,但另一方面,你不想由于大量的 polyfill 影響使用戶體驗(yàn)。

另一方面,即使你希望將其發(fā)布到較新的瀏覽器中,也不必?fù)?dān)心私有類字段。最起碼現(xiàn)在是這樣。甚至Firefox都沒有實(shí)施該建議。

以上就是詳解JavaScript私有類字段和TypeScript私有修飾符的詳細(xì)內(nèi)容,更多關(guān)于JavaScript私有類字段和TypeScript私有修飾符的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 国产成人啪精品视频免费软件 | 国产一区二区三区免费看 | 免费在线观看a级片 | 成人性欧美丨区二区三区 | 美女一级毛片免费观看 | 欧美三级黄色 | 成人亚洲在线观看 | 成人区精品一区二区不卡亚洲 | 免费人成在线观看播放国产 | www.99热| 男人性天堂 | 久久成人免费 | 亚洲成a人v大片在线观看 | 亚洲综色 | 久久精品最新免费国产成人 | 男女男精品视频免费观看 | 一个人看的www日本高清视频 | 99久久伊人一区二区yy5o99 | 国产一区二区三区亚洲综合 | 亚洲欧美网址 | 高清大学生毛片一级 | 真人一级毛片 | 天堂在线视频网站 | 日韩欧美一中字暮 | 真人一级一级特黄高清毛片 | a级片在线观看免费 | 久久国内免费视频 | 亚洲免费观看视频 | 一级做a爱久久久久久久 | 国产精品成人观看视频免费 | 亚洲欧美日韩国产一区二区精品 | 综合色久 | 日本又黄又爽又免费 | 足恋玩丝袜脚视频免费网站 | 成人禁在线观看午夜亚洲 | 亚洲国产情侣一区二区三区 | 亚洲精品日韩中文字幕久久久 | 日韩美女一级视频 | 真实一级一级一片免费视频 | 在线观看中文字幕一区 | 一 级 黄 色 大片 |