📄
fe-share
  • fe-share
  • JavaScript
    • Canvas 图片处理
    • Javascript 性能
    • JavaScript 原型(2) - 原型与原型链
    • JavaScript 原型(1) - 构造函数
    • JavaScript - Promise
    • Canvas 灰度
    • ES6 解构赋值
    • Proxy
    • Object.defineProperty()简介
  • Engineering
    • 登录鉴权
    • 缓存
    • Chrome-devtools
    • Docker
    • 技术架构演化
    • Git
    • webpack
    • BS 架构与 CS 架构
    • SVN(Subversion)
    • gulp
    • 前端架构
  • MachineLearning
    • GAN生成对抗网络
    • 虚拟对抗训练
    • 深度度量学习
    • 原型网络
    • 联邦学习
    • 机器学习常见评价指标
    • Transformer算法
    • Self-attention 推荐算法
    • CNN 卷积神经网络
    • 集成学习算法
    • RNN循环神经网络
    • PyTorch安装和基本操作
  • CSS
    • 什么是BFC
  • React
    • React 生命周期
    • Hooks
    • SWR
    • React 数据流
  • 跨端
    • Flutter 介绍
  • Golang
    • Golang 基础
  • Vue
    • nextTick()的使用
    • vue-cli2.x 的使用与项目结构分析
    • Vue响应式原理及总结
    • VueX的使用
    • 记录一个问题的探索过程
  • Node
    • Node 优势
    • Node Stream
    • Node 模块系统
  • AR
    • SceneKit
由 GitBook 提供支持
在本页
  • setter/getter
  • Proxy

这有帮助吗?

  1. JavaScript

Proxy

setter/getter

JavaScript 支持 setter 和 getter 已经很长时间了。他们用带有 set 和 get 关键字的简单语法来拦截对象的属性访问和值的修改操作。

例如

const obj = {
  propValue: 1,
  get prop() {
    console.log("Retrieving property prop");
    return this.propValue;
  },
  set prop(value) {
    console.log("Setting property prop to", value);
    this.propValue = value;
  },
};

setter/getter 有多个缺点:它们仅限 get 和 get 操作(显然)。它们不能与相同键(即"常规"属性)的数据入口一起使用。它们不是动态的,必须在对象声明期间用静态的 Object.defineProperty() 方法或通过使用计算值(仅适用于新的浏览器)显式地应用于每个属性。

Proxy

代理是内置的 JS 对象,可用于拦截和更改与对象相关的不同操作的行为。

const originalObj = {
  prop: 1,
  anotherProp: "value",
};
const proxyObj = new Proxy(originalObj, {
  get(obj, prop) {
    console.log("Retrieving property", prop);
    return obj[prop];
  },
  set(obj, prop, value) {
    console.log("Setting property", prop, "to", value);
    obj[prop] = value;
    return true;
  },
});
originalObj.prop;
originalObj.prop = 2;
proxyObj.prop;

Proxy 会创建一个新对象供你与之交互,而不是与原始对象进行交互,原始对象在使用 setter/getter 时会直接修改

使用静态的 Proxy.revocable() 方法可撤销代理

上一页ES6 解构赋值下一页Object.defineProperty()简介

最后更新于4年前

这有帮助吗?

在使用 Proxy 的情况下,原始对象(也称为 target)用作一种存储。你对其执行的任何操作都会直接影响代理,但不会触发其任何 trap。代理的 是执行特定操作时调用的简单方法。它们都是在单个 handler 对象上定义的,然后传递给 Proxy 构造函数。除此之外,它们不仅限于 set() 和 get()

trap