浅谈js声明私有变量的两种方法及作用
Admin 2021-04-25 群英技术资讯 723 次浏览
闭包的描述有很多种,比如:能访问其它函数作用域的函数;内部函数访问外部函数作用域的桥梁;......
使用闭包构建私有变量的逻辑在于:
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 : xiaoming console.log('xiaohong name : ' + xiaohong.getName());//xiaohong name : xiaohong xiaoming.setAge(19.3333); xiaohong.setAge('16');//Uncaught Error: typeof age !== 'number' console.log('xiaoming age : ' + xiaoming.getAge());//xiaoming age : 19 console.log('xiaohong age : ' + xiaohong.getAge());//xiaohong age : 18 xiaoming.setSex(1); xiaohong.setSex('woman'); console.log('xiaoming sex : ' + xiaoming.getSex());//xiaoming sex : man console.log('xiaohong sex : ' + xiaohong.getSex());//xiaohong sex : woman
从上面的代码中,可以看出,如果想要设置或者获取 _name、_age、_sex三个变量的值,只能通过固定的 setName、getName、setAge、getAge、setSex、getSex等方法,而在所有的setter方法中,都对形参进行了判断。也就意味着,对对象的所有操作都将在掌控之中,这在某一层面上弱化了JavaScript作为弱类型语言上的一些负面影响。
如果对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 : xiaoming console.log('xiaohong name : ' + xiaohong.getName());//xiaohong name : xiaohong xiaoming.setAge(19.3333); xiaohong.setAge('16');//Uncaught Error: typeof age !== 'number' console.log('xiaoming age : ' + xiaoming.getAge());//xiaoming age : 19 console.log('xiaohong age : ' + xiaohong.getAge());//xiaohong age : 18 xiaoming.setSex(1); xiaohong.setSex('woman'); console.log('xiaoming sex : ' + xiaoming.getSex());//xiaoming sex : man console.log('xiaohong sex : ' + xiaohong.getSex());//xiaohong sex : woman
同样达成了构建私有变量的效果。顺便提一句,class中构建私有变量用的就是WeakMap。
这篇文章只是记录我知道的关于JavaScript构建私有变量的方法以及作用,如有错误和遗漏,欢迎指出,不胜感谢。
以上就是js声明私有变量的两种方式介绍,希望对大家有帮助,更多JS相关内容大家可以继续浏览其他文章。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
方法:1、声明一个验证数字的正则表达式,语法为“var a=/^[1-9][0-9]+$/gi;”;2、在if语句中利用test()方法来验证数字,语法为“if(a.test(指定内容)){是数字代码;}else{不是数字代码;}”。
方法:1、使用“for (var i=1;i<=n;i++){}”语句控制循环遍历范围为“1~n”;2、循环体中,使用“sum=sum+i;”语句将1到n的数相加,和值赋值给变量sum;3、循环结束后,变量sum的值就1到n的和,输出即可。
线程和进程是计算机操作系统的基础概念,在程序员中属于高频词汇,那如何理解呢?Node.js 中的进程和线程又是怎样的呢?下面本篇文章就来一起了解一下,希望对大家有所帮助!
TypeScript语法详解之类型操作的补充 目录 类型操作的补充 类型断言的使用 非空类型的断言 可选链使用介绍 两个特殊操作符 字面量类型介绍 字面量推理介绍 总结 类型操作的补充 类型断言的使用 有时候TypeScript无法获取具体的类型信息,这个我们需要使用类型断言( Type Assertions). 比如我们在操作DOM的时候, 通过 document.getElementById 获取元素, TypeScript只知道该函数会返回HTMLElement ,但并不知道它具体的类型, 是无法得知具体是img还是div等等: 当我
这篇文章主要介绍了JavaScript字典与集合详解,集合是由一组无序且不重复的元素构成。我们可以将集合看成一种特殊的数组,它的特殊之处就是无序且不重复,这也就意味着我们不能通过下标的方式进行访问,而且集合中不会出现重复的元素
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008