vue2响应式 VS vue3响应式

Vue2响应式

存在问题:
新增属性,删除属性,界面不会更新。
直接通过下标修改数组界面不会自动更新。
在这里插入图片描述
在这里插入图片描述
Vue2使用object.defineProperty来劫持数据是否发生改变,如下:
在这里插入图片描述
在这里插入图片描述
能监测到获取和修改属性:
在这里插入图片描述
新增的属性没有get和set:
在这里插入图片描述
删除name属性:
在这里插入图片描述
综上,获取和修改一个属性可以捕获到,但是新增和删除属性是捕获不到的,所以使用 s e t 和 set和 setdelete方法才能响应。

Vue3实现响应式

  1. 如下代码,p = new Proxy()后,p是一个proxy对象,是person的一个代理对象,对p的修改会映射到person身上:
    在这里插入图片描述
    在这里插入图片描述
    上面代码只是说P是person的代理对象,p改变,person跟着改变,但是并没有做到响应式,也就是变化并没有捕获到。
  2. Vue3捕获响应:
    在这里插入图片描述
    结果如下:对对象的增删改查全部捕获到,并且映射到person中。
    其中set方法,既捕获新增又捕获修改。

在这里插入图片描述
3. 对上面代码进行优化,vue3中是使用Reflect来对数据进行修改。

在这里插入图片描述

综上,实现原理:
#通过proxy(代理):拦截对象中任意属性的变化,包括:属性值的读写,属性的添加,属性的删除等。 通过Reflect(反射):对被代理对象(原对象)的属性进行操作。

相关推荐

  1. vue2响应vue3响应

    2024-04-20 13:18:10       11 阅读
  2. VUE3-响应

    2024-04-20 13:18:10       37 阅读
  3. Vue3---基础4(响应数据) Vue2

    2024-04-20 13:18:10       15 阅读
  4. vue2vue 3响应原理

    2024-04-20 13:18:10       6 阅读
  5. vue响应原理

    2024-04-20 13:18:10       36 阅读
  6. vue响应基础

    2024-04-20 13:18:10       14 阅读
  7. Vue2源码】响应原理

    2024-04-20 13:18:10       23 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-20 13:18:10       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-20 13:18:10       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-20 13:18:10       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-20 13:18:10       20 阅读

热门阅读

  1. matlab简单统计学预测方法分析

    2024-04-20 13:18:10       12 阅读
  2. RX.Net 第二章 hello Word

    2024-04-20 13:18:10       13 阅读
  3. CentOS常见命令

    2024-04-20 13:18:10       13 阅读
  4. Ubuntu 22.04上text-generation-webui service文件编写思路

    2024-04-20 13:18:10       13 阅读
  5. 电流电压;为什么用铜线作为导体

    2024-04-20 13:18:10       13 阅读
  6. 深度解析:国内实时音视频厂商核心功能对比

    2024-04-20 13:18:10       12 阅读