JS中如何創(chuàng)建私有變量示例詳解
1、使用閉包(Closure) 模擬私有變量
通過使用閉包,可以將私有變量封裝在一個函數(shù)的作用域內(nèi),外部無法直接訪問這些私有變量。閉包可以保證私有變量的封裝性和安全性。
function MyClass() { // 私有變量 let privateVar = 'I am private'; // 公共方法 this.getPrivateVar = function() { return privateVar; } this.setPrivateVar = function(value) { privateVar = value; } } const myInstance = new MyClass(); console.log(myInstance.getPrivateVar()); // "I am private" myInstance.setPrivateVar('New Value'); console.log(myInstance.getPrivateVar()); // "New Value" console.log(myInstance.privateVar); // undefined (無法直接訪問私有變量)
privateVar 是通過閉包實現(xiàn)的私有變量,外部代碼無法直接訪問它。
通過 getPrivateVar 和 setPrivateVar 方法可以間接訪問和修改私有變量。
具體來說:
- privateVar 是一個 局部變量,它被封閉在 MyClass 構(gòu)造函數(shù)內(nèi)部。
- getPrivateVar 和 setPrivateVar 函數(shù)能夠訪問并操作這個局部變量,即使它們被返回并在 MyClass 構(gòu)造函數(shù)外部執(zhí)行。這樣,privateVar 就保持了私有性,不會被外部直接訪問。
閉包的特性在此體現(xiàn):
- 詞法作用域:函數(shù)在定義時就會記錄它所能訪問的變量范圍,而不僅僅是在執(zhí)行時。
- 訪問私有數(shù)據(jù):通過閉包,外部代碼不能直接訪問 privateVar,但可以通過公共方法(如 getPrivateVar 和 setPrivateVar)間接訪問或修改它。
其中詞法作用域,又叫靜態(tài)作用域,變量被創(chuàng)建時就確定好了,而非執(zhí)行階段確定的。也就是說我們寫好代碼時它的作用域就確定了,JavaScript 遵循的就是詞法作用域。
2、使用 ES6 Symbol(符號) 模擬私有變量
Symbol 是 ES6 引入的一個新的基本數(shù)據(jù)類型,它可以用作對象的唯一屬性鍵,避免外部直接訪問。你可以用 Symbol 來創(chuàng)建私有變量。
Symbol 是 在 ES6引入的一種原始數(shù)據(jù)類型。它代表了一個獨一無二的、不可變的值。每個通過 Symbol() 創(chuàng)建的 Symbol 值都是唯一的,即使它們有相同的描述,也會被視為不同的值。
const privateVar = Symbol('privateVar'); class MyClass { constructor() { this[privateVar] = 'I am private'; } getPrivateVar() { return this[privateVar]; } setPrivateVar(value) { this[privateVar] = value; } } const myInstance = new MyClass(); console.log(myInstance.getPrivateVar()); // "I am private" myInstance.setPrivateVar('New Value'); console.log(myInstance.getPrivateVar()); // "New Value" console.log(myInstance[privateVar]); // undefined (無法直接訪問私有變量)
使用 Symbol 可以避免變量名沖突,且 privateVar 作為一個 Symbol 類型,外部無法直接訪問它。
具體而言:
- privateVar 是一個 Symbol,它作為對象 MyClass 的私有屬性鍵。
- this[privateVar] 存儲了私有變量的值,并且外部無法直接通過 myInstance.privateVar 或 myInstance[‘privateVar’] 訪問它,因為它是由Symbol 創(chuàng)建的,外部不知道該 Symbol 的值。
- 通過 getPrivateVar 和 setPrivateVar 方法,外部可以間接訪問或修改這個私有變量的值。
3、使用 WeakMap 模擬私有變量
WeakMap 是一個鍵值對集合,鍵是對象,值可以是任意類型。利用 WeakMap,可以將私有數(shù)據(jù)存儲在一個外部的 WeakMap 中,確保數(shù)據(jù)與對象的生命周期關(guān)聯(lián),同時避免外部直接訪問私有數(shù)據(jù)。
const privateVars = new WeakMap(); class MyClass { constructor() { privateVars.set(this, { privateVar: 'I am private' }); } getPrivateVar() { return privateVars.get(this).privateVar; } setPrivateVar(value) { privateVars.get(this).privateVar = value; } } const myInstance = new MyClass(); console.log(myInstance.getPrivateVar()); // "I am private" myInstance.setPrivateVar('New Value'); console.log(myInstance.getPrivateVar()); // "New Value" console.log(privateVars.get(myInstance)); // { privateVar: 'New Value' } (直接訪問 WeakMap)
privateVars 存儲了對象實例的私有數(shù)據(jù),WeakMap 會將數(shù)據(jù)與對象的生命周期關(guān)聯(lián),不會阻止垃圾回收。
4、使用 ES2022 的 # 私有字段
在 ES2022 中,JavaScript 引入了類的私有字段(#)。使用 # 前綴定義的字段在類的外部無法直接訪問,這是一種新的原生私有變量實現(xiàn)方式。
class MyClass { #privateVar; // 私有字段 constructor() { this.#privateVar = 'I am private'; } getPrivateVar() { return this.#privateVar; } setPrivateVar(value) { this.#privateVar = value; } } const myInstance = new MyClass(); console.log(myInstance.getPrivateVar()); // "I am private" myInstance.setPrivateVar('New Value'); console.log(myInstance.getPrivateVar()); // "New Value" console.log(myInstance.#privateVar); // SyntaxError: Private field '#privateVar' must be declared in an enclosing class
#privateVar 是私有字段,外部無法訪問它,只有類的方法可以訪問。
總結(jié)
到此這篇關(guān)于JS中如何創(chuàng)建私有變量的文章就介紹到這了,更多相關(guān)JS創(chuàng)建私有變量內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實現(xiàn)的文本框placeholder提示文字功能示例
這篇文章主要介紹了JavaScript實現(xiàn)的文本框placeholder提示文字功能,涉及javascript事件響應及頁面元素屬性動態(tài)操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2018-07-07JS實現(xiàn)iframe編輯器光標位置插入內(nèi)容的方法(兼容IE和Firefox)
這篇文章主要介紹了JS實現(xiàn)iframe編輯器光標位置插入內(nèi)容的方法,可實現(xiàn)文本與圖片的插入功能,并兼容IE和Firefox瀏覽器,需要的朋友可以參考下2016-06-06基于JS實現(xiàn)移動端訪問PC端頁面時跳轉(zhuǎn)到對應的移動端網(wǎng)頁
不想通過CSS自適應在PC端和移動端分別顯示不同的樣式,那么只能通過在移動端訪問PC端網(wǎng)頁時跳轉(zhuǎn)到對應的移動端網(wǎng)頁了,那么怎么跳轉(zhuǎn)呢,網(wǎng)上也有很多文章說明,以下實現(xiàn)思路經(jīng)過小編測試過,需要的朋友可以參考下2016-04-04JavaScript實現(xiàn)手寫promise的示例代碼
promise?作為前端開發(fā)中常用的函數(shù),解決了?js?處理異步時回調(diào)地獄的問題,大家應該也不陌生了,今天來學習一下?promise?的實現(xiàn)過程吧2023-04-04