我的编程空间,编程开发者的网络收藏夹
学习永远不晚

proxy实现vue3数据双向绑定原理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

proxy实现vue3数据双向绑定原理

一、proxy对比Object.defineProperty的优点

proxy的优点:

  • Proxy 可以直接监听对象而非属性;
  • Proxy 可以直接监听数组的变化;
  • Proxy 有多达 13 种拦截方法,不限于 apply、ownKeys、deleteProperty、has 等等是Object.defineProperty 不具备的;
  • Proxy 返回的是一个新对象,我们可以只操作新的对象达到目的,而 Object.defineProperty 只能遍历对象属性直接修改;
  • Proxy 作为新标准将受到浏览器厂商重点持续的性能优化,也就是传说中的新标准的性能红利;

Object.defineProperty 的优势:

兼容性好:支持 IE9,而 Proxy 的存在浏览器兼容性问题,而且无法用 polyfill 磨平,因此 Vue 的作者才声明需要等到下个大版本( 3.0 )才能用 Proxy 重写。

二、、proxy监听对象的简单实现

1.代理对象简单实现


```javascript
let data = {};// 定义一个空对象
let proxy = new Proxy(data, {});// 创建一个 Proxy , 将 data 作为目标对象
// 修改Proxy 代理对象的name属性
proxy.name = 'shelley';
console.log(proxy); 
console.log(data)
// { name: 'shelley' }
// { name: 'shelley' }

```

2.补充知识 Reflect

Reflect对象与Proxy对象一样,也是 ES6 为了操作对象而提供的新 API

我们需要在 handler.set() 中 return 一个 Reflect.set(…arguments) 来进行赋值给目标对象。

  • Reflect.set方法设置target对象的name属性等于value。如果name属性设置了赋值函数,则赋值函数的this绑定receiver。
  • Reflect.get方法查找并返回target对象的name属性,如果没有该属性,则返回undefined。

3.proxy方法

handler.set()方法 属性设置操作的捕捉器。


```javascript
let data = {
  name: 'shelley',
  age: '27'
};
let p = new Proxy(data, {
  set(target, prop, value) {
    // target = 目标对象
    // prop = 设置的属性
    // value = 修改后的值
    console.log(target, prop, value);  // { name: 'shelley', age: '27' } age 18
    return Reflect.set(...arguments);
  }
})
p.age = 18;
console.log(data);  // { name: 'shelley', age: 18 }
```

- handler.get() 属性读取操作的捕捉器。


```javascript
let data = {
  name: 'shelley',
  age: 22
};
let p = new Proxy(data, {
  get(target, prop){
    console.log(target, prop);//{ name: 'shelley', age: 22 } age
    return Reflect.get(...arguments);
  }
})
console.log(p.age);//22
```

Object.defineProperty监听对象的简单实现


```javascript
var o = {};// 创建一个新对象
var bValue = 39;// 在对象中添加一个设置了存取描述符属性的示例
Object.defineProperty(o, 'bValue', {  
  // 这代码不会设置 o 的属性,只有访问的时候才会
  get() {
    return bValue;
  },
  set(newValue) {
    console.log('set==>', newValue);
    bValue = newValue;
  }
});
console.log(o) // {}
// 进入访问器代理的bValue属性的get方法,返回,并设置o对象里的bValue的值为38
console.log(o.bValue); // 38
// 进入访问器代理的bValue属性的set方法,设置bValue的新值,
// 再进入get返回,并设置o对象里的bValue的值为40
o.bValue = 40;
console.log(o.bValue) // 40
```

小结:

  • es6 proxy代理器对比es5 Object.defineProperty,功能更加强大,提供了方法超多,甚至可以代理方法
  • 为什么vue3.0才使用es6的proxy,未在2.0就使用;因为es6在部分浏览器中并未兼容,如ie的低版本,所以在**大部分主流浏览器都兼容**的情况下,才使用

三、手写vue3.0双向绑定-es6 Proxy

1、什么是Proxy

  • Proxy取其英文意思即“代理”。所谓代理,是你要取得某样东西或对其进行某些操作的中间媒介,而不是直接作用在这个对象上。
  • Proxy可以理解成在目标对象前架设一层拦截层,外界访问该对象都必须先通过这层拦截,因此提供一种机制可以对外界的访问进行拦截或过滤。

2、vue.js中使用双向绑定


```javascript
<div id="app">
  <h2>{{msg}}</h2>
  <input type="text" v-model="msg"/>
</div>
<script class="lazy" data-src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script>
  let vm = new Vue({
  el: '#app',
  data: {
    msg: 'shelley'
},
})
</script>


```

四、Proxy对比Object.defineProperty

Vue2.0中的双向绑定,使用Object.defineProperty()进行双向绑定

缺点:

  • 无法对数组进行监听,采用的是对数组的方法进行重写(push, pop,shift,unshift等等)。对此进行双向绑定和数据监听的操作
  • 效率差,这主要是因为对多层数据进行一次性的递归操作,如果数据很多或者是很深层次,这样性能非常的差
  • 因为局限性,无法对新加/删除的数据进行监听,所以使用在vue2.0中使用$set进行手动添加

- Object.definePorperty()递归遍历所有对象的所有属性,当数据层级较深时,会造成性能影响。

- Object.definePorperty()只能作用在对象上,不能作用在数组上。

- Object.definePorperty()只能监听定义时的属性,不能监听新增属性。

- 由于Object.definePorperty()不能作用于数组,vue2.0选择通过重写数组方法原型的方式对数组数据进行监听,但是仍然无法监听数组索引的变化和长度的变更

Vue3.0中双向绑定,使用Proxy和Reflect进行双向绑定

优点:

  • Proxy可以对数组和对象进行拦截和监听

缺点:

  • Proxy会出发多次set/get响应

解决办法:

  • ①使用类似于debounce的操作,对其进行优化,使其值响应一次
  • ②(vue3.0中的解决方式),判断key是否是target的自身属性,以及value是否和target[key]相等,可以避免多余的set/get操作

Proxy只能代理一层,无法深度监听

  • ①使用深度递归,对每一层进行监听。巧妙的使用的Reflect.get()会返回对象内层结构的特性(下一层),判断下一层是否还是对象,并且使用深度递归操作。但是在性能上又很大的影响
  • ②使用weakMap,使用两个weakMap来保存原始数据和可响应数据。访问数据时会从保存的数据中查找,如果没有再对其进行Proxy操作。

到此这篇关于proxy实现vue3数据双向绑定原理的文章就介绍到这了,更多相关proxy实现vue3数据双向绑定 内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

proxy实现vue3数据双向绑定原理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

proxy怎么实现数据的双向绑定

本篇内容介绍了“proxy怎么实现数据的双向绑定”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.写在前面随着 vue3.x 的消息越来越多
2023-06-03

vue双向数据绑定原理分析、vue2和vue3原理的不同点

这篇文章主要介绍了vue双向数据绑定原理分析、vue2和vue3原理的不同点,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-08

Android数据双向绑定原理实现和应用场景

本文介绍了Android数据双向绑定的原理和实现方式,包括基于观察者模式和数据绑定框架的实现方法,以及应用场景和优缺点的分析,帮助开发者了解和应用数据双向绑定技术,提升应用的交互性和响应速度
2023-05-17

Vue2.0/3.0双向数据绑定的实现原理是什么

这篇文章给大家分享的是有关Vue2.0/3.0双向数据绑定的实现原理是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。vue是什么Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框
2023-06-14

vue2.x双向数据绑定原理解析

双向数据绑定原理主要运用了发布订阅模式来实现的,通过Object.defineProperty对数据劫持,触发getter,setter方法,这篇文章主要介绍了vue2.x双向数据绑定原理,需要的朋友可以参考下
2023-02-27

Vue双向绑定原理及实现方法

Vue双向绑定是指数据模型和视图之间的数据同步,通过Object.defineProperty()方法实现数据劫持,利用观察者模式实现数据更新和视图更新的自动同步,实现方式包括指令、计算属性、v-model等,优化方法包括使用虚拟DOM、合理使用computed和watch等
2023-05-17

vue双向数据绑定怎么实现

Vue的双向数据绑定是通过v-model指令来实现的。1. v-model是Vue提供的一个指令,用于在表单元素上实现双向数据绑定。可以将v-model绑定到一个Vue实例的data属性上,这样在表单元素中输入的值会自动同步到Vue实例的d
2023-08-09

MVVMLight怎么实现双向数据绑定

这篇文章主要介绍“MVVMLight怎么实现双向数据绑定”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MVVMLight怎么实现双向数据绑定”文章能帮助大家解决问题。第一步:先写一个Model,里面
2023-06-29

vue2.x双向数据绑定原理是什么

这篇文章主要介绍了vue2.x双向数据绑定原理是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue2.x双向数据绑定原理是什么文章都会有所收获,下面我们一起来看看吧。前言双向数据绑定原理主要运用了发布订阅
2023-07-05

vue如何实现数据双向绑定

Vue.js是一个流行的前端框架,它提供了多种方式来实现数据双向绑定。数据双向绑定是Vue.js最重要的特性之一,它使得开发者能够根据数据的变化自动更新视图,同时也能根据视图的变化自动更新数据。因此,Vue.js的数据双向绑定也成为前端面试题中常被问到的问题。本篇文章将着重介绍Vue.js实现数据双向绑定的原理及其具体实现方法。一、原理Vue.js的数据双向绑定是基于MVVM(
2023-05-14

vue 数据双向绑定怎么实现

这篇文章给大家分享的是有关vue 数据双向绑定怎么实现的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 前言实现简易版的数据双向绑定2. 代码实现2.1 目的分析本文要实现的效果如下图所示:本文用到的HTML和
2023-06-06

angular双向数据绑定怎么实现

Angular双向数据绑定可以通过以下步骤来实现:1. 在HTML模板中使用双大括号({{}})将数据绑定到HTML元素上。例如:{{myData}}。2. 在组件类中定义和初始化要绑定的数据属性。例如,在组件类中定义一个名为myData的
2023-09-21

编程热搜

目录