js中私有变量的创建的几种方法

本文介绍了JavaScript中创建私有变量的四种方法:利用闭包、Symbol、对象属性及面向对象的getter/setter。通过示例代码详细展示了每种方法的实现过程,帮助读者理解如何在类和对象中实现数据的私有化,防止外部直接访问和修改私有成员。

js中私有变量的创建的几种方法

0、原理

类的开发者和使用者不是一个人

1、闭包

// 内部可以访问,但是外部不能访问
(function(name){
    // 闭合空间都是私有的
    return function(){

    }
})()

2、在constructor中用Symbol()代替key

用symbol做了一个新的key

// 类的开发者, 调用者
class Login{
    constructor(username,password){
        const PASSWORD = Symbol();
        this.username = username
        // 使用Symbol 规避了公共访问
        this[PASSWORD] = password;
        // 1. {} key
        // 2. 怎么存进对象? key不可访问呢?私有
        // 3. symbol
    }
    checkPassword(pwd){
        return this[PASSWORD] == pwd
    }
}

var userA = new Login('aa','123456');
// userA.password = '123456';
console.log(userA.username)  //aa
console.log(userA.password)  //undefined

3、用对象以Symbol定义

const gender = Symbol('gender');
const obj = {
    name:'大胖猫',
    age:'3',
    [gender]:'公'
}
//obj.name  
obj[gender]  //调用成功 
// 不可枚举
console.log(Object.keys(obj));
console.log(JSON.stringify(obj));

遍历object的方法:

均未成功调用出gender

console.log(Object.keys(obj));
console.log(JSON.stringify(obj));

仅调用出symbol的方法:

console.log(Object.getOwnPropertySymbols(obj));

调用出包括symbol的全部元素

console.log(Reflect.ownKeys(obj));

4、优化面向对象的读写操作

class Person{
    constructor(name){
        this.name = name;   // 公有属性

    }
    get name(){
        console.log('get 方法');
        return this.name;
    }
    set name(str){
        console.log('设置了name 方法');
        this.name = str;
    }
}
let coco = new Person('coco');
console.log(coco.name);
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值