Vue 3 的双向绑定原理

ops/2024/11/30 10:58:22/

Vue 3 的双向绑定原理是基于 响应式系统数据劫持 技术来实现的。在 Vue 3 中,双向绑定通常是通过 v-model 指令来完成的,它本质上是数据的双向同步:当数据改变时,视图自动更新,反之,视图的修改也会更新到数据。

Vue 3 双向绑定的原理分析

1. 响应式系统(reactivity

Vue 3 使用了新的响应式系统来追踪对象属性的依赖关系。当一个数据发生变化时,Vue 会自动通知依赖的组件重新渲染。

  • Proxy API:Vue 3 基于 Proxy 对象来实现数据的代理,这样可以在数据访问时设置拦截器(getter 和 setter),从而实现数据的响应式。
  • 依赖收集和触发更新:当组件访问某个响应式数据时,Vue 会在该属性的 getter 中收集依赖(即当前组件的渲染函数)。当该数据发生变化时,Vue 会触发 setter,通知相关的依赖(组件)更新。
2. 双向绑定的核心原理

在 Vue 中,双向绑定的关键是 v-model 指令。我们通过 v-model 在父子组件之间同步数据。具体来说,Vue 通过以下几个步骤来实现双向绑定:

  1. 组件数据初始化
    在组件中,父组件会传递一个值给子组件,子组件通过 v-model 绑定该值。Vue 会通过 props 将父组件的数据传递给子组件,子组件在内部将这个值设置为响应式数据。

  2. v-model 的双向绑定

    • 在子组件中,v-model 会自动将 value 作为 props,并且会把 @update:modelValue 作为事件来处理数据的双向绑定。
    • v-model 本质上会在组件中生成一个 modelValue(或通过自定义修改名称的形式)作为 props,并且会监听子组件的 @update:modelValue 事件来同步数据回父组件。
  3. 数据的同步

    • 当用户在子组件中的输入框、选择框等表单元素发生改变时,事件会触发(例如 inputchange 事件),通过 @update:modelValue 事件把新的值传递给父组件。
    • 父组件收到更新的值后,通过 v-model 再更新它的值,触发子组件重新渲染,完成双向绑定。
3. 代码示例

父组件:

<template><ChildComponent v-model="parentData" />
</template><script>
import { ref } from 'vue'
import ChildComponent from './ChildComponent.vue'export default {components: { ChildComponent },setup() {const parentData = ref('Hello World')return { parentData }}
}
</script>

子组件(ChildComponent):

<template><input type="text" :value="modelValue" @input="updateValue" />
</template><script>
export default {props: {modelValue: {type: String,required: true}},emits: ['update:modelValue'],setup(props, { emit }) {const updateValue = (event) => {emit('update:modelValue', event.target.value)}return { updateValue }}
}
</script>
4. v-model 的工作原理
  • v-model 会绑定到子组件的 modelValue prop 和父组件的变量(如 parentData)。当子组件的 input 改变时,触发 @input 事件,通过 update:modelValue 事件将新的值传递回父组件,从而完成双向绑定。

总结

Vue 3 的双向绑定实现是通过:

  1. 响应式系统(Proxy + Dependency Tracking)来追踪数据变化。
  2. v-model 指令来实现父子组件间的数据同步。
  3. 事件触发和数据更新(通过 @update:modelValue)实现父子数据的双向绑定。

这种方式相比于 Vue 2 中的 Object.definePropertydata 方式,Vue 3 的响应式系统更加高效且易于扩展。


http://www.ppmy.cn/ops/137908.html

相关文章

小程序 - 婚礼邀请函

小程序页面和样式练习 - 婚礼邀请函小程序开发笔记 目录 婚礼邀请函 准备工作 加载静态资源 项目初始化 标签栏的配置 各页面导航栏标题配置 全局导航栏样式配置 公共样式的编写 项目内容 邀请函页面内容 邀请函页面样式 照片页面内容 照片墙页面样式 美好时光页…

Ubuntu桥接模式设置静态IP

目录 关于 NAT VS 桥接 为桥接模式配置静态IP 编辑虚拟机设置 虚拟网络编辑器 选择要桥接的网络适配器 固定桥接该网络适配器 确定静态IP与网关 虚拟机内更改 桌面可直接更改设置 非桌面版可以更改配置文件 关于Windows网络适配器&#xff08;可以改&#xff09;…

信创改造 - Redis -》TongRDS 安装方式之单节点模式安装

安装前准备 安装 JDK 参考链接&#xff1a;安装 JDK 8【Linux】 语雀 创建用户 # 用户名可以自己起 useradd rds 上传安装包到服务器 单节点模式是由两个部署单元组成&#xff1a;1 个RDS 服务节点&#xff0c;1 个 RDS 中心节点。 上传到 /home/rds 用户文件夹&#xff0…

解析类的泛型参数 Spring之GenericTypeResolver.resolveTypeArgument

GenericTypeResolver 是 Spring 的一个实用类&#xff0c;提供了在运行时解析泛型类型信息的能力。它包含了若干静态方法&#xff0c;可以用于解析类的泛型参数。GenericTypeResolver.resolveTypeArgument 方法可以用于解析一个具体类实现指定的泛型接口时&#xff0c;实际的泛…

Git 的使用

Git 初始 个人本机使用&#xff1a;Git 基础命令和概念 多人共享使用&#xff1a;团队开发同一个项目的代码版本管理 Git 安装 检验安装是否成功&#xff1a; 打开 bash 终端&#xff08;git 专用&#xff09; 命令&#xff1a;git -v&#xff08;查看版本号&#xff09;…

黑客基础之html(超文本标记语言)

黑客基础之html&#xff08;超文本标记语言&#xff09; HTML&#xff08;超文本标记语言&#xff09;是一种用于创建网页的标准标记语言。它描述了网页的结构和内容&#xff0c;通过一系列的元素和标签来定义文本、图像、链接、表格、表单等网页元素。HTML不是一种编程语言&a…

uniapp的video组件截图(抓拍)功能,解决截后为黑图bug

废话不多说先上代码&#xff01;&#xff01;&#xff01;&#xff01; 点击截图按钮触发以下方法 getCapture() {let _this thislet pages getCurrentPages();let page pages[pages.length - 1];let ws page.$getAppWebview();let bitmap new plus.nativeObj.Bitmap(te…

[HNCTF 2022 WEEK2]TTTTTTTTTea

下载附件&#xff0c;用ida打开。 反编译&#xff0c;查看源码。 v4感觉就是密文&#xff0c;进入tea_encrypt中查看加密方式&#xff1a; 就是一个数据转换。 在查看key&#xff0c;找到密钥。 这里是需要转换为四个八位的数&#xff0c;因为一个int是四个字节&#xff0c;一…