Es6的Proxy代理是什么?有哪些用法?

一.什么是Proxy?

Proxy 对象是ES6新出的一个特性,用于创建一个对象的代理,从而实现基本操作的拦截和自定义(如属性查找、赋值、枚举、函数调用等)。

需要知道的是,在Vue2中双向数据绑定原理(数据劫持)采用Object.defineProperty,而在Vue3中数据劫持原理采用的是Proxy代理。

二.为什么Proxy会取代Object.defineProperty?

Object.defineProperty只能劫持对象的属性,不能监听数组。也不能对 es6 新产生的 Map,Set 这些数据结构做出监听。也不能监听新增和删除操作等等。

Proxy可以直接监听整个对象而非属性,可以监听数组的变化,具有多达13中拦截方法。

总而言之,Proxy 对象是ES6新出的一个特性,用于创建一个对象的代理,从而实现基本操作的拦截和自定义(如属性查找、赋值、枚举、函数调用等)。在Vue3中数据劫持原理采用的是Proxy代理。Proxy可以直接监听整个对象而非属性,可以监听数组的变化,具有多达13中拦截方法。

● get(target,propKey,receiver):拦截对象属性的读取

● set(target,propKey,value,receiver):拦截对象属性的设置

● has(target,propKey):拦截propKey in proxy的操作,返回一个布尔值

● deleteProperty(target,propKey):拦截delete proxy[propKey]的操作,返回一个布尔值

● ownKeys(target):拦截Object.keys(proxy)、for...in等循环,返回一个数组

● getOwnPropertyDescriptor(target, propKey):拦截Object.getOwnPropertyDescriptor(proxy, propKey),返回属性的描述对象

● defineProperty(target, propKey, propDesc):拦截Object.defineProperty(proxy, propKey, propDesc),返回一个布尔值

● preventExtensions(target):拦截Object.preventExtensions(proxy),返回一个布尔值

● getPrototypeOf(target):拦截Object.getPrototypeOf(proxy),返回一个对象

● isExtensible(target):拦截Object.isExtensible(proxy),返回一个布尔值

● setPrototypeOf(target, proto):拦截Object.setPrototypeOf(proxy, proto),返回一个布尔值

● apply(target, object, args):拦截 Proxy 实例作为函数调用的操作

● construct(target, args):拦截 Proxy 实例作为构造函数调用的操作

相关推荐
郁大锤10 分钟前
Flask与 FastAPI 对比:哪个更适合你的 Web 开发?
前端·flask·fastapi
HelloRevit1 小时前
React DndKit 实现类似slack 类别、频道拖动调整位置功能
前端·javascript·react.js
ohMyGod_1232 小时前
用React实现一个秒杀倒计时组件
前端·javascript·react.js
eternal__day2 小时前
第三期:深入理解 Spring Web MVC [特殊字符](数据传参+ 特殊字符处理 + 编码问题解析)
java·前端·spring·java-ee·mvc
醋醋2 小时前
Vue2源码记录
前端·vue.js
艾克马斯奎普特2 小时前
Vue.js 3 渐进式实现之响应式系统——第四节:封装 track 和 trigger 函数
javascript·vue.js
江耳2 小时前
从10秒到无限流:我用Vercel+NextJS实现AI流式对话遇到的超时问题及解决方案
前端
总之就是非常可爱2 小时前
三分钟让你看懂alien-signals computed基本原理
前端
JustHappy2 小时前
「我们一起做组件库🌻」虚拟消息队列?message组件有何不同?(VersakitUI开发实录)
前端·javascript·vue.js
Carlos_sam2 小时前
Openlayers:为Overlay创建element的四种方式
前端·javascript·vue.js