亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

JavaScript 聲明私有變量的兩種方式

瀏覽:97日期:2023-10-04 14:14:09
前言

JavaScript并不像別的語言,能使用關鍵字來聲明私有變量。我了解的JavaScript能用來聲明私有變量的方式有兩種,一種是使用閉包,一種是使用WeakMap。

閉包

閉包的描述有很多種,比如:能訪問其它函數作用域的函數;內部函數訪問外部函數作用域的橋梁;......

使用閉包構建私有變量的邏輯在于:1.在外部函數中聲明變量和內部函數;2.使用內部函數訪問或者修改變量值;3.在外部函數內返回內部函數;

function outside(){let val = 123;function inside(){return val;}return inside;}console.log(outside()());//123

通過我上面的例子能夠大致了解使用閉包構建私有變量的邏輯,但是不足以體現私有變量的重要性,一個const變量也能達到上述代碼的效果:

//同樣的能訪問,但是不能修改,達到了上述代碼的效果const val = 123;console.log(val);//123

接下來的代碼,將具體體現私有變量的重要性:

function person(){ let _name = ’unknown’; let _age = 18; let _sex = ’man’; function setName(name){ _name = name || ’unknown’; } function getName(){ return _name; } function setAge(age){ if(typeof age === ’number’){ _age = Math.floor(age); }else{ throw Error('typeof age !== ’number’'); } } function getAge(){ return _age; } function setSex(sex){ if(sex === ’man’ || sex === 1){ _sex = ’man’; }else if(sex === ’woman’ || sex === 0){ _sex = ’woman’; }else{ throw Error(’input error’); } } function getSex(){ return _sex; } return { setName : setName, getName : getName, setAge : setAge, getAge : getAge, setSex : setSex, getSex : getSex }}let xiaoming = person();let xiaohong = person();xiaoming.setName(’xiaoming’);xiaohong.setName(’xiaohong’);console.log(’xiaoming name : ’ + xiaoming.getName());//xiaoming name : xiaomingconsole.log(’xiaohong name : ’ + xiaohong.getName());//xiaohong name : xiaohongxiaoming.setAge(19.3333);xiaohong.setAge(’16’);//Uncaught Error: typeof age !== ’number’console.log(’xiaoming age : ’ + xiaoming.getAge());//xiaoming age : 19console.log(’xiaohong age : ’ + xiaohong.getAge());//xiaohong age : 18xiaoming.setSex(1);xiaohong.setSex(’woman’);console.log(’xiaoming sex : ’ + xiaoming.getSex());//xiaoming sex : manconsole.log(’xiaohong sex : ’ + xiaohong.getSex());//xiaohong sex : woman

從上面的代碼中,可以看出,如果想要設置或者獲取 _name、_age、_sex三個變量的值,只能通過固定的 setName、getName、setAge、getAge、setSex、getSex等方法,而在所有的setter方法中,都對形參進行了判斷。也就意味著,對對象的所有操作都將在掌控之中,這在某一層面上弱化了JavaScript作為弱類型語言上的一些負面影響。

WeakMap

如果對WeakMap不是很了解的可以先看WeakMap的詳細介紹。這里主要是利用WeakMap的key不可枚舉這一知識點。

let nameWeakMap = new WeakMap();let ageWeakMap = new WeakMap();let sexWeakMap = new WeakMap();function person(){ let _hash = Object.create(null); nameWeakMap.set(_hash,’unknown’); ageWeakMap.set(_hash,18); sexWeakMap.set(_hash,’man’); function setName(name){ nameWeakMap.set(_hash,name || ’unknown’); } function getName(){ return nameWeakMap.get(_hash); } function setAge(age){ if(typeof age === ’number’){ ageWeakMap.set(_hash,Math.floor(age)); }else{ throw Error('typeof age !== ’number’'); } } function getAge(){ return ageWeakMap.get(_hash); } function setSex(sex){ if(sex === ’man’ || sex === 1){ sexWeakMap.set(_hash,’man’); }else if(sex === ’woman’ || sex === 0){ sexWeakMap.set(_hash,’woman’); }else{ throw Error(’input error’); } } function getSex(){ return sexWeakMap.get(_hash); } return { setName : setName, getName : getName, setAge : setAge, getAge : getAge, setSex : setSex, getSex : getSex }}let xiaoming = person();let xiaohong = person();xiaoming.setName(’xiaoming’);xiaohong.setName(’xiaohong’);console.log(’xiaoming name : ’ + xiaoming.getName());//xiaoming name : xiaomingconsole.log(’xiaohong name : ’ + xiaohong.getName());//xiaohong name : xiaohongxiaoming.setAge(19.3333);xiaohong.setAge(’16’);//Uncaught Error: typeof age !== ’number’console.log(’xiaoming age : ’ + xiaoming.getAge());//xiaoming age : 19console.log(’xiaohong age : ’ + xiaohong.getAge());//xiaohong age : 18xiaoming.setSex(1);xiaohong.setSex(’woman’);console.log(’xiaoming sex : ’ + xiaoming.getSex());//xiaoming sex : manconsole.log(’xiaohong sex : ’ + xiaohong.getSex());//xiaohong sex : woman

同樣達成了構建私有變量的效果。順便提一句,class中構建私有變量用的就是WeakMap。

結尾

這篇文章只是記錄我知道的關于JavaScript構建私有變量的方法以及作用,如有錯誤和遺漏,歡迎指出,不勝感謝。

以上就是JavaScript 聲明私有變量的兩種方式的詳細內容,更多關于JavaScript 聲明私有變量的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 亚洲一区二区三区久久精品 | 日韩国产片 | 91一区二区在线观看精品 | 精品在线观看免费 | 首页国产精品萌社区 | 日本老太婆一级毛片免费 | 国产国产精品人在线观看 | 亚洲人成网站999久久久综合 | 久久国产精品只做精品 | 欧美精品亚洲二区 | 五月天六月婷婷 | 91探花在线播放 | 三级国产在线 | 国产毛片在线看 | 一级做a爰片欧美aaaa | 久久精品久久精品 | xxxx成年视频免费 | 黄色网址网站 | 黄色在线视频免费看 | 九九精品热线免费观看6 | 一级片 720p| 欧美特级限制片高清 | 亚洲色图在线视频 | 国产最爽的乱淫视频国语对 | 爱爱视频在线免费观看 | 91视频最新| 亚洲人与牲动交xxxxbbbb | 福利午夜 | 久99久热只有精品国产99 | 朴妮唛1一30集福利在线播放 | 99久久一区二区精品 | 久草国产精品视频 | 亚洲无线一二三四手机 | 欧美色视频免费高清播放 | 国产在线麻豆一区二区 | 91精品手机国产免费 | 丁香五月亚洲综合在线 | 午夜视频你懂的 | 美国一级黄色片 | 国产精品久久久久久久人人看 | 亚洲二区在线视频 |