当前位置: 首页 > news >正文

ES6更新的内容中什么是proxy

Proxy 是 ES6(ECMAScript 2015)中引入的一个新的内置对象,用于定义某些操作的自定义行为(如属性查找、赋值、枚举、函数调用等)。Proxy 可以被看作是一个拦截器,它拦截并自定义对象上的基本操作。通过创建一个对象的 Proxy,你可以控制对这个对象的访问,包括读取属性、设置属性、枚举属性、函数调用等。

Proxy 接收两个参数:

  1. 目标对象(target):你想要拦截其操作的对象。
  2. 处理器对象(handler):一个对象,其属性是当执行一个操作时定义代理的行为的函数。

处理器对象可以定义零个或多个捕获器(trap),这些捕获器是定义在处理器对象上的特定函数,用于拦截并处理目标对象上的操作。

示例

下面是一个简单的 Proxy 示例,它拦截了对目标对象属性的读取和设置操作:

const target = {  foo: 'bar',  log: ['hello', 'world']  
};  const handler = {  get: function(target, prop, receiver) {  console.log(`Getting ${prop}!`);  return Reflect.get(...arguments);  },  set: function(target, prop, value, receiver) {  console.log(`Setting ${prop} = ${value}`);  return Reflect.set(...arguments);  }  
};  const proxy = new Proxy(target, handler);  console.log(proxy.foo); // 输出: Getting foo! 然后是 bar  
proxy.foo = 'baz'; // 输出: Setting foo = baz  
console.log(proxy.foo); // 再次输出: Getting foo! 然后是 baz

在这个例子中,handler 对象定义了两个捕获器:getset。当尝试读取 proxy.foo 时,会触发 get 捕获器,并输出相应的日志。同样,当尝试设置 proxy.foo 的值时,会触发 set 捕获器,并输出相应的日志。

使用场景

Proxy 的使用场景非常广泛,包括但不限于:

  • 数据绑定:自动更新 DOM 或其他数据表示,以响应对象的变化。
  • 性能监控:在对象访问时记录日志,以便进行性能分析。
  • 函数调用:拦截和修改函数调用,例如添加日志、权限检查等。
  • 私有属性:通过捕获器控制对对象属性的访问,实现类似私有属性的效果。

Proxy 是一个非常强大的特性,它允许开发者以声明式的方式拦截和修改对象的操作,从而提供了高度的灵活性和控制力。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 力扣8.29
  • React多功能管理平台项目开发全教程
  • C++ | Leetcode C++题解之第387题字符串中的第一个唯一字符
  • Go入门:gin框架极速搭建图书管理系统
  • MySQL:复合查询
  • 深度学习(二)
  • minio最新源码编译(处理安全扫描中跨域访问、.js.map等不安全问题)
  • SQLite3 数据类型深入全面讲解
  • 【PyQt】切换界面的实现
  • day-45 全排列 II
  • 【机器学习】循环神经网络(RNN)介绍
  • MySQL集群技术4——MySQL路由
  • 【大模型】Reflextion解读
  • P01-何谓Java方法
  • Nginx: 使用KeepAlived配置实现虚IP在多服务器节点漂移及Nginx高可用原理
  • 【Amaple教程】5. 插件
  • 2017年终总结、随想
  • Angularjs之国际化
  • Elasticsearch 参考指南(升级前重新索引)
  • express.js的介绍及使用
  • gf框架之分页模块(五) - 自定义分页
  • httpie使用详解
  • Java新版本的开发已正式进入轨道,版本号18.3
  • java正则表式的使用
  • Js实现点击查看全文(类似今日头条、知乎日报效果)
  • rabbitmq延迟消息示例
  • vagrant 添加本地 box 安装 laravel homestead
  • WordPress 获取当前文章下的所有附件/获取指定ID文章的附件(图片、文件、视频)...
  • 电商搜索引擎的架构设计和性能优化
  • 理解 C# 泛型接口中的协变与逆变(抗变)
  • 聊聊spring cloud的LoadBalancerAutoConfiguration
  • 思考 CSS 架构
  • 微信小程序填坑清单
  • 用mpvue开发微信小程序
  • 在 Chrome DevTools 中调试 JavaScript 入门
  • AI又要和人类“对打”,Deepmind宣布《星战Ⅱ》即将开始 ...
  • 阿里云重庆大学大数据训练营落地分享
  • ​低代码平台的核心价值与优势
  • #Datawhale X 李宏毅苹果书 AI夏令营#3.13.2局部极小值与鞍点批量和动量
  • (1)无线电失控保护(二)
  • (2021|NIPS,扩散,无条件分数估计,条件分数估计)无分类器引导扩散
  • (仿QQ聊天消息列表加载)wp7 listbox 列表项逐一加载的一种实现方式,以及加入渐显动画...
  • (附源码)springboot助农电商系统 毕业设计 081919
  • (附源码)ssm本科教学合格评估管理系统 毕业设计 180916
  • (解决办法)ASP.NET导出Excel,打开时提示“您尝试打开文件'XXX.xls'的格式与文件扩展名指定文件不一致
  • (亲测成功)在centos7.5上安装kvm,通过VNC远程连接并创建多台ubuntu虚拟机(ubuntu server版本)...
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • (一)SvelteKit教程:hello world
  • (译) 理解 Elixir 中的宏 Macro, 第四部分:深入化
  • (轉貼) 2008 Altera 亞洲創新大賽 台灣學生成果傲視全球 [照片花絮] (SOC) (News)
  • ./mysql.server: 没有那个文件或目录_Linux下安装MySQL出现“ls: /var/lib/mysql/*.pid: 没有那个文件或目录”...
  • .cn根服务器被攻击之后
  • .htaccess配置重写url引擎
  • .NET CF命令行调试器MDbg入门(四) Attaching to Processes
  • .NET Micro Framework初体验(二)