序文
他の言語とは異なり、JavaScriptはキーワードを使用してプライベート変数を宣言できます。
JavaScriptを使用してプライベート変数を宣言する方法は2つあることを理解しています。1つは使用する方法です。閉鎖、1つは使用することです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 : 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
上記のコードから、3つの変数_name、_age、_sexの値を設定または取得する場合は、固定のsetName、getName、setAge、getAge、setSex、getSexなどのみを使用できることがわかります。セッター法では、正式なパラメーターが判断されます。これは、オブジェクトに対するすべての操作が制御下にあることを意味します。これにより、特定のレベルで、弱い型の言語としてのJavaScriptの悪影響の一部が弱まります。
WeakMap
WeakMapについてよく知らない場合は、最初にWeakMapの詳細な紹介を読むことができます。
これは主に、WeakMapのキーが列挙できないという知識を使用するためです。
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
プライベート変数を作成する効果も実現されます。ちなみに、WeakMapはクラス内のプライベート変数を構築するために使用されます。
終わり
この記事は、プライベート変数を作成するためのJavaScriptの方法と機能について私が知っていることを記録するためのものです。エラーや欠落がある場合は、それらを指摘してください。ありがとうございます。