本文介绍: Proxy 对象是ES6新出的一个特性,用于创建一个对象的代理,从而实现基本操作的拦截和自定义(如属性查找、赋值、枚举、函数调用等)。  需要知道的是,在Vue2中双向数据绑定原理(数据劫持)采用Object.defineProperty,而在Vue3中数据劫持原理采用的是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 实例作为构造函数调用的操作

原文地址:https://blog.csdn.net/jiyc2008/article/details/135414455

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_53546.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注