【Javascript高级知识】使用ES6实现私有变量的四种实现方式总结

本文总结了使用ES6实现私有变量的四种方法:通过闭包、Symbol、WeakMap以及最新的提案。详细介绍了如何在Person类中创建公共的name属性和私有的age及sex属性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ES6 实现私有变量方式总结

需求如下

实现一个Person类,设计下面的类
name : public
age : private
sex : private

1. 使用闭包的方式来实现

const Person = (function() {
  let _sex = '';
  let _age = 0;
  class Person {
      constructor(name, age, sex){
          this.name = name;
          _age = age;
          _sex = sex;
      }
      
      getName(){
          return this.name;
      }
      
      getAge(){
          return _age;
      }
      
      getSex(){
          return _sex;
      }
  }
  return Person;
})();

let p1 = new Person('zhangsan', 16, 'MALE');
let p2 = new Person('lisi', 43, 'FEMALE');
console.log(p1.getName(), p1.getAge(), p1.getSex(), p1.name, p1._age, p1._sex); // zhangsan 16 MALE zhangsan undefined undefined
console.log(p2.getName(), p2.getAge(), p2.getSex(), p2.name, p2._age, p2._sex); // lisi 43 FEMALE lisi undefined undefined

2. 使用Symbol来实现

const Person = (function() {
  const _age = Symbol('_age');
  const _sex = Symbol('_sex');
  class Person {
      constructor(name, age, sex){
          this.name = name;
          this[_age] = age;
          this[_sex] = sex;
      }
      
      getName(){
          return this.name;
      }
      
      getAge(){
          return this[_age];
      }
      
      getSex(){
          return this[_sex];
      }
  }
  
  return Person;
})();

let p1 = new Person('zhangsan', 16, 'MALE');
let p2 = new Person('lisi', 43, 'FEMALE');
console.log(p1.getName(), p1.getAge(), p1.getSex(), p1.name, p1._age, p1._sex); // zhangsan 16 MALE zhangsan undefined undefined
console.log(p2.getName(), p2.getAge(), p2.getSex(), p2.name, p2._age, p2._sex); // lisi 43 FEMALE lisi undefined undefined

3.使用WeakMap来实现

const Person = (function() {
  const _age = new WeakMap();
  const _sex = new WeakMap();
  class Person {
      constructor(name, age, sex){
          this.name = name;
          _age.set(this, age);
          _sex.set(this, sex);
      }
      
      getName(){
          return this.name;
      }
      
      getAge(){
          return _age.get(this);
      }
      
      getSex(){
          return _sex.get(this);
      }
  }
  
  return Person;
})();

let p1 = new Person('zhangsan', 16, 'MALE');
let p2 = new Person('lisi', 43, 'FEMALE');

console.log(p1.getName(), p1.getAge(), p1.getSex(), p1.name, p1._age, p1._sex); // zhangsan 16 MALE zhangsan undefined undefined
console.log(p2.getName(), p2.getAge(), p2.getSex(), p2.name, p2._age, p2._sex); // lisi 43 FEMALE lisi undefined undefined

4. 使用最新的提案来实现

const Person = (function() {
  #age;
  #sex;
  class Person {
      constructor(name, age, sex){
          this.name = name;
          this.#age = age;
          this.#sex = sex;
      }
      
      getName(){
          return this.name;
      }
      
      getAge(){
          return this.#age;
      }
      
      getSex(){
          return this.#sex;
      }
  }
  
  return Person;
})();

let p1 = new Person('zhangsan', 16, 'MALE');
let p2 = new Person('lisi', 43, 'FEMALE');

console.log(p1.getName(), p1.getAge(), p1.getSex(), p1.name, p1._age, p1._sex); // zhangsan 16 MALE zhangsan undefined undefined
console.log(p2.getName(), p2.getAge(), p2.getSex(), p2.name, p2._age, p2._sex); // lisi 43 FEMALE lisi undefined undefined
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值