IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> JavaScript私有属性方法的三种实现过程 -> 正文阅读

[JavaScript知识库]JavaScript私有属性方法的三种实现过程

大家可能知道ES11已经从官方规范上实现了“私有”的概念,不管是私有属性还是私有方法都只需要在前面加上“#“即可,但是ES11版本太新,担心可能很多浏览器不能很好的支持,并不是所有用户都会使用Chrome,对吧? 所以这一次我们从ES5开始到ES6实现私有化的概念

一、ES5闭包

'use strict'
//第一种
const Test=function(){
  //定义私有属性
  let privateAttr; 


  function Test(id){  
      privateAttr="我是私有属性"
      this.publicAttr="我是对象公有属性";
      privateFun=privateFun.bind(this); //改变私有方法this指向
  }


  //私有方法
  function privateFun(){
    console.log(privateAttr); //访问私有变量
    console.log(this.publicAttr); //访问对象属性
  }

  return Test;

}();


const t=new Test();
console.log(t.publicAttr); //我是对象公有属性
console.log(t.privateAttr); //undefined
console.log(t.privateFun); //undefined

看到这,如果你就是想访问publicAttr的值,不妨在Test原型上添加一个”特权方法“,将私有变量的值返回出去即可。

二、ES6 Symbol

'use strict'
const Test=function(){
  const privateAttr = Symbol('private');
  const privateFun = Symbol('private');
  function Test(){
    this[privateAttr]=9;
    this.attr=1;
    this[privateFun](); //调用私有方法
  }

  Test.prototype.add=function(){
    this[privateAttr]=this[privateAttr]+1;
    console.log(`私有属性+1得到的结果${this[privateAttr]}`);

    this.attr=this.attr+1;
    console.log(`对象属性+1得到的结果${this.attr}`);
  }

  Test.prototype[privateFun]=function(){
    console.log("这里是私有方法");
    console.log(`私有属性是${this[privateAttr]}`);
  }
  
  return Test;
}();

const t=new Test();  //这里是私有方法  私有属性是9
t.add();  //私有属性+1得到的结果10 对象属性+1得到的结果2

privateAttr privateFun 的值都是 Symbol('private'),但是他们内部得到的引用不一样,这就是Symbol的好处,使用Symbol 使得私有方法也能在原型上定义,避免了不必要的this指向问题,这个方法优于上面的方法

三、ES6?WeakMap和Symbol

'use strict'
const Test=function(){
  const wm=new WeakMap();

  function Test(){
    this.attr="对象属性";

    this.privateAttr=Symbol('private');
    this.privateFun=Symbol('private');
    const privateMem=wm.get(this) || {};
    privateMem[this.privateAttr]="private Attribute";
    privateMem[this.privateFun]=privateFun.bind(this);
    wm.set(this,privateMem);
  }

  function privateFun(){
    wm.get(this)[this.privateAttr]="new private Attribute";
    console.log(`改变后私有变量的值是 ${wm.get(this)[this.privateAttr]}`);
    console.log(`对象属性 ${this.attr}`);
  }

  Test.prototype.show=function(){
    console.log(`私有属性的值: ${wm.get(this)[this.privateAttr]}`);
    
    wm.get(this)[this.privateFun](); //调用私有方法
  }
  return Test;
}();

const t=new Test();
t.show();

//私有属性的值: private Attribute
//改变后私有变量的值是 new private Attribute
//对象属性 对象属性

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-24 11:20:57  更:2021-07-24 11:22:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 12:03:33-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码