浅谈下javascript的proxy和reflect
近日喜欢上了uniapp和vue,但看到相关程序代码中频繁出现了proxy和reflect的使用,于是进行了一番学习,现总结如下。
Proxy和Reflect是ES6(ECMAScript 2015)引入的两个新的特性,它们共同提供了一种可编程的方式,用于拦截、修改、和定义JavaScript对象的基本行为。在这里,我将简单介绍Proxy和Reflect的概念,以及它们的用法。
Proxy是一个代理对象,它可以用来拦截JavaScript对象的一些基本操作。代理对象包装了目标对象,并可以在目标对象上定义各种拦截器。拦截器是一些函数,它们被调用以响应目标对象的行为。例如,当代理对象的属性被访问时,拦截器可以拦截这个行为并返回一个不同的值,或者抛出一个错误。
下面是一个例子,展示了如何使用Proxy来拦截对象的读取操作:
const target = {
name: "Alice",
age: 30
};
const handler = {
get: function(target, prop) {
console.log(`Reading property '${prop}'`);
return target[prop];
}
};
const proxy = new Proxy(target, handler);
console.log(proxy.name); // 输出 "Reading property 'name'" 和 "Alice"
在这个例子中,我们定义了一个代理对象proxy,它包装了一个目标对象target。我们还定义了一个拦截器handler,其中的get方法被调用以拦截proxy对象的属性读取操作。当我们使用proxy.name读取代理对象的name属性时,拦截器会输出一条日志并返回目标对象的name属性值。
Proxy是一种代理对象,它允许你定义自定义的行为,例如:属性的读取和赋值、函数调用、构造函数调用等等。当你创建一个代理对象时,你可以传递一个处理程序对象,这个处理程序对象定义了代理对象的行为。例如:
let obj = new Proxy({}, {
get(target, prop) {
console.log(`Getting property "${prop}"`);
return target[prop];
},
set(target, prop, value) {
console.log(`Setting property "${prop}" to "${value}"`);
target[prop] = value;
}
});
obj.foo = "bar";
console.log(obj.foo); // 输出 "Getting property "foo" bar"
在上面的代码中,我们创建了一个空对象的代理,然后定义了一个处理程序对象,该处理程序对象将处理代理对象的属性访问。当我们给代理对象设置一个属性时,代理对象会调用设置属性的处理程序,该处理程序会输出一条消息。当我们获取代理对象的属性时,代理对象会调用获取属性的处理程序,该处理程序也会输出一条消息。
Reflect则是一个内置对象,它提供了一组方法来操作JavaScript对象。Reflect的方法与一些对象操作的方法(例如Object.defineProperty和Object.create)非常相似,但是Reflect方法更加一致和易于使用,并且可以作为函数调用。Reflect提供的方法与Proxy对象的拦截器方法相对应。Reflect方法返回值与Proxy对象的拦截器方法返回值是相同的。这些方法包括Reflect.get()、Reflect.set()、Reflect.has()、Reflect.deleteProperty()等等。例如:
let obj = { foo: "bar" };
Reflect.set(obj, "foo", "baz"); // 设置 "foo" 的值为 "baz"
console.log(Reflect.get(obj, "foo")); // 输出 "baz"
在上面的代码中,我们使用Reflect.set方法设置了obj对象的"foo"属性的值为"baz",然后使用Reflect.get方法获取了obj对象的"foo"属性的值。与Proxy类似,Reflect还提供了许多其他方法,例如Reflect.construct用于调用构造函数,Reflect.defineProperty用于定义属性等等。
下面是一个例子,展示了如何使用Reflect来代替对象操作:
const obj = { a: 1 };
console.log(obj.a); // 输出 1
const proxy = new Proxy(obj, {
get: function(target, prop, receiver) {
console.log(`Reading property '${prop}'`);
return Reflect.get(target, prop, receiver);
}
});
console.log(proxy.a); // 输出 "Reading property 'a'" 和 1
在这个例子中,我们使用Reflect的get方法来代替了拦截器方法中的return target[prop]。这种方式使代码更简洁和易于维护,因为我们可以使用标准的对象操作方法,同时还可以在拦截器中进行自定义操作。
总之,Proxy和Reflect是一对非常强大的特性,它们可以帮助我们更灵活、更可控地操作JavaScript对象。使用它们,我们可以实现一些很酷的功能,例如数据验证、对象代理
浅谈下javascript的proxy和reflect的更多相关文章
- 浅谈ES6中的Proxy
Proxy是一个很有趣的对象,它能够修改某些操作的默认行为,等同于在语言层面做出修改,属于一种‘元编程’,即对编程语言进行编程. Proxy其实很好理解,就是在目标对象之前架设一层拦截,外界的访问都得 ...
- 浅谈前端JavaScript编程风格
前言 多家公司和组织已经公开了它们的风格规范,详细可參阅jscs.info,以下的内容主要參考了Airbnb的JavaScript风格规范.当然还有google的编程建议等编程风格 本章探讨怎样使用E ...
- 浅谈原生JavaScript的动画和特效
一.JavaScript中的动画原理 动画效果的实现总的来说可分为两种,一种是利用纯css实现,该方法在css3成熟后广泛应用:另外一种是通过JavaScript(或者一些封装的库如jQuery的an ...
- 浅谈Array --JavaScript内置对象
Array --JavaScript内置对象 描述 可以用一个变量存储多种数据类型的Array对象,Array不是关联数组,不能使用字符串作为索引访问数组元素,需要使用非负整数的下标访问数组中的元素. ...
- 浅谈 原生javaScript&&react 实现全局触摸按钮(附带对addeventlistener的了解)
1.采用原生javaACript 实现全局触摸按钮 首先在控制台输出,观察事件有哪些关于触摸的字段可以使用,然后拿这些字段的数据开始来写方法. 因为要做的是全局触摸按钮,我需要拿到的是按钮时时的坐标位 ...
- 浅谈原生JavaScript实现remove()和recover()
利用原生JavaScript实现: 1.remove(selectors)删除指定的一个或一组元素. 2.recover(selectors)恢复刚才删除的元素. function remove(se ...
- 浅谈 原生javaScript && react 实现全局触摸按钮(附带对addeventlistener的了解)
1.采用原生javaACript 实现全局触摸按钮 首先在控制台输出,观察事件有哪些关于触摸的字段可以使用,然后拿这些字段的数据开始来写方法. 因为要做的是全局触摸按钮,我需要拿到的是按钮时时的坐标位 ...
- 浅谈JavaScript中闭包
引言 闭包可以说是JavaScript中最有特色的一个地方,很好的理解闭包是更深层次的学习JavaScript的基础.这篇文章我们就来简单的谈下JavaScript下的闭包. 闭包是什么? 闭包是什么 ...
- 浅谈Nginx负载均衡和F5的区别
前言 笔者最近在负责某集团网站时,同时用到了Nginx与F5,如图所示,负载均衡器F5作为处理外界请求的第一道"墙",将请求分发到web服务器后,web服务器上的Nginx再进行处 ...
- 浅谈Objective—C中的面向对象特性
Objective-C世界中的面向对象程序设计 面向对象称程序设计可能是现在最常用的程序设计模式.如何开发实际的程序是存在两个派系的-- 面向对象语言--在过去的几十年中,很多的面向对象语言被发明出来 ...
随机推荐
- Centos7安装MySQL详细步骤(配置开机自启)
MySQL 检查系统是否安装过mysql //检查系统中有无安装过mysql rpm -qa|grep mysql //查询所有mysql 对应的文件夹,全部删除 whereis mysql find ...
- BootStrap Table 添加序列号
js $('#table').bootstrapTable({ striped: true,//隔行换色 columns: [ { field: '', title: '序号', sortable: ...
- 类、事件与对象---Dad&Mom简单练习
目的: 模拟一个家庭日常发生的场景:妈妈做好饭,说:"开饭了!",这是爸爸听到了妈妈的喊话就立马动身开始饭吃.而儿子此时正在打游戏,于是他就说:"等我打完这把游戏再吃!& ...
- thinkphp模型hasOne、hasMany、belongsTo详解
在ThinkPHP框架中,hasOne.hasMany和belongsTo是用于定义模型间一对多(1:n).一对一(1:1)和多对一(n:1)关联关系的方法.以下是一些简单的示例来解释这些关系: 1. ...
- C# EPPlus帮助类(EPPlusExcelHelper)
public class EPPlusExcelHelper : IDisposable { public ExcelPackage ExcelPackage { get; private set; ...
- 什么是spring.factories,引入未知模块报错如何解决
对于maven中引入其他外部包加入容器的过程,需要用到spring.factories spring.factories的作用:将自动配置类与对应的配置类集中在一起,方便springboot自动装配, ...
- Activity活动生命相关
启动与结束 页面跳转: startActivity(new Intent(this,xxxx.class)); 关闭当前界面返回上一界面 finish(); //这里我在使用finish遇到一个问题, ...
- app专项测试:app弱网测试(网络测试流程)
app专项测试:app弱网测试(网络测试流程) 一.网络测试的一般流程 step1:首先要考虑网络正常的情况 ① 各个模块的功能正常可用 ② 页面元素/数据显示正常 step2:其次要考虑无网络的情况 ...
- Fiddler关于https抓包
一.Fiddler默认只抓取HTTP请求 Fiddler安装后默认只抓取HTTP请求,如要抓取HTTPS请求需要进行证书安装 二.Fiddler导出HTTPS证书 1.勾选HTTPS 工具栏Tools ...
- Jmeter函数助手40-escapeHtml
escapeHtml函数用于将字符串进行HTML转义. 字符串转义:填入字符串 1.escapeHtml函数是将字符换进行HTML转义,jmeter还存在其它格式化函数如urlencode函数,url ...