位置: IT常识 - 正文

【Vue2从入门到精通】详解Vue数据双向绑定原理及手动实现双向绑定(vue2-elm)

编辑:rootadmin
【Vue2从入门到精通】详解Vue数据双向绑定原理及手动实现双向绑定 文章目录✨什么是数据双向绑定✨数据双向绑定的原理✨Vue数据双向绑定原理✨实现数据双向绑定的步骤✨手动实现自定义组件的双向绑定的步骤✨写在最后

推荐整理分享【Vue2从入门到精通】详解Vue数据双向绑定原理及手动实现双向绑定(vue2-elm),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue2教程,vue 入门,vue2-elm,vue2-elm,vue2.0教程,vue2.,vue2教程,vue2-elm,内容如对您有帮助,希望把文章链接给更多的朋友!

✨什么是数据双向绑定

我们先从单向绑定切入单向绑定非常简单,就是把Model绑定到View。

什么是双向绑定呢?当我们用JavaScript代码更新Model时,View就会自动更新,在单向绑定的基础上,用户更新了View,Model的数据也自动被更新了,这种情况就是双向绑定。

✨数据双向绑定的原理

数据双向绑定的原理之前,我们先来了解一下什么是MVVM。

MVVM是一种设计思想,它是Model-View-ViewModel的缩写。它也是MVC的增强版。

Model是代表数据模型,也可以在Model中定义数据修改和操作的业务逻辑。View是代表UI组件,它负责将数据模型转化成UI展现出来。ViewModel是一个同步View和Model的对象。

ViewModel的主要职责:

数据变化后更新视图视图变化后更新数据

当然,它还有两个主要部分组成

监听器(Observer):对所有数据的属性进行监听解析器(Compiler):对每个元素节点的指令进行扫描跟解析,根据指令模板替换数据,以及绑定相应的更新函数✨Vue数据双向绑定原理

Vue是采用数据劫持结合发布者-订阅者模式的方式,通过使用ES5中的Object.defineProperty()方法来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应的监听回调来渲染视图。

Object.defineProperty()允许在对象上定义新的属性,以及修改或删除现有属性的特性,其中包括get、set、enumerable和configurable等。

【Vue2从入门到精通】详解Vue数据双向绑定原理及手动实现双向绑定(vue2-elm)

✨实现数据双向绑定的步骤创建Vue实例时,在data属性中定义需要双向绑定的数据。在模板中使用v-model指令将输入控件绑定到数据属性上。 在Vue内部,使用Object.defineProperty()方法将数据属性转换为getter/setter形式,从而实现数据的响应式变化。当输入控件的值发生变化时,Vue会自动调用数据属性的setter方法,从而更新数据的值。当数据的值发生变化时,Vue会自动更新相关的DOM元素,从而实现数据与视图的双向绑定。

示例代码如下:

html

<div id="app"> <input v-model="message"> <p>{{ message }}</p></div>

javascript

var vm = new Vue({ el: '#app', data: { message: '' }});

在上面的代码中,v-model指令将输入框和message属性进行了双向绑定。当输入框的值发生变化时,message属性的setter方法会被调用,从而更新数据。当message属性的值发生变化时,相关的DOM元素也会自动更新,从而实现了数据与视图的双向绑定。

需要注意的是,Vue的双向绑定仅适用于一些特定的输入控件,如input、textarea和select等。对于自定义组件,需要手动实现数据的双向绑定。

如何手动实现数据的双向绑定呢?请继续往下看。

✨手动实现自定义组件的双向绑定的步骤在自定义组件中,通过props属性接收父组件传递的数据,并在组件中定义一个内部变量来保存这些数据。在组件内部使用v-model指令将输入控件绑定到内部变量上。在组件内部监听输入控件的变化事件,并在事件处理函数中更新内部变量的值。在组件内部通过$emit()方法触发一个自定义事件,并将内部变量作为参数传递给父组件。在父组件中使用自定义事件的处理函数来更新父组件中的数据。

示例代码如下:

<!-- 父组件 --><template> <div> <my-component v-model="message"></my-component> <p>{{ message }}</p> </div></template><script> import MyComponent from './MyComponent.vue'; export default { components: { 'my-component': MyComponent }, data() { return { message: '' } } }</script><!-- 自定义组件 --><template> <div> <input type="text" v-model="internalValue"> </div><template><script> export default { props: ['value'], data() { return { internalValue: '' } }, mounted() { this.internalValue = this.value; }, watch: { internalValue() { this.$emit('input', this.internalValue); } } }</script>

在上面的代码中,我们定义了一个名为value的props属性来接收父组件传递的数据,同时定义了一个名为internalValue的内部变量来保存这些数据。在组件挂载后,我们将value的值赋值给internalValue。

在组件内部使用v-model指令将输入控件绑定到internalValue上。当输入控件的值发生变化时,我们使用watch来监听internalValue的变化事件,并在事件处理函数中使用$emit()方法触发一个名为input的自定义事件,并将internalValue作为参数传递给父组件。

在父组件中,我们可以通过v-model指令将message属性与自定义组件的value属性进行双向绑定。当自定义组件的input事件被触发时,我们可以在事件处理函数中将事件的参数作为message属性的值进行更新。

示例代码如下:

<!-- 父组件 --><template> <div> <my-component v-model="message"></my-component> <p>{{ message }}</p> </div></template><script> import MyComponent from './MyComponent.vue'; export default { components: { 'my-component': MyComponent }, data() { return { message: '' } } }</script><!-- 自定义组件 --><template> <div> <input type="text" v-model="internalValue"> </div></template><script> export default { props: ['value'], data() { return { internalValue: '' } }, mounted() { this.internalValue = this.value; }, watch: { internalValue() { this.$emit('input', this.internalValue); } } }</script>

在上面的代码中,我们定义了一个名为message的数据属性,并将它与自定义组件的value属性进行了双向绑定。

同时,在自定义组件中,我们实现了数据的双向绑定,并通过$emit()方法触发了一个名为input的自定义事件来与父组件进行通信。这样就实现了自定义组件的双向绑定。

✨写在最后✨ 原创不易,希望各位大佬多多支持。👍 点赞,你的认可是我创作的动力。⭐️ 收藏,感谢你对本文的喜欢。✏️ 评论,你的反馈是我进步的财富。
本文链接地址:https://www.jiuchutong.com/zhishi/300665.html 转载请保留说明!

上一篇:es6新增哪些特性(es6特性及使用场景)

下一篇:jQuery 获取与设置 元素属性【一篇文章轻松拿下】(jquery获取值的几种方法)

  • 苹果微信支付怎么设置面部识别(苹果微信支付怎么关闭)

    苹果微信支付怎么设置面部识别(苹果微信支付怎么关闭)

  • 微信手机号搜索该用户不存在(微信手机号搜索记录怎么查)

    微信手机号搜索该用户不存在(微信手机号搜索记录怎么查)

  • hd5300相当于什么显卡(hd5300参数)

    hd5300相当于什么显卡(hd5300参数)

  • 麒麟710和810差别大吗(麒麟710和麒麟810的区别在哪里)

    麒麟710和810差别大吗(麒麟710和麒麟810的区别在哪里)

  • 老电脑有2G必要升级4G内存吗(老电脑有2g必要升级4g内存还是8G)

    老电脑有2G必要升级4G内存吗(老电脑有2g必要升级4g内存还是8G)

  • 把拉黑的人移出黑名单对方能看到吗(把拉黑的人移出群聊)

    把拉黑的人移出黑名单对方能看到吗(把拉黑的人移出群聊)

  • 荣耀v20有导航键么(荣耀20手机导航键设置)

    荣耀v20有导航键么(荣耀20手机导航键设置)

  • oppo手机老是黑屏死机怎么办(oppo手机老是黑屏一闪一闪)

    oppo手机老是黑屏死机怎么办(oppo手机老是黑屏一闪一闪)

  • 隐藏会话关联看得到吗(隐藏会话关联会看到吗)

    隐藏会话关联看得到吗(隐藏会话关联会看到吗)

  • 苹果平板微信版本低登录不了怎么办(苹果平板微信版本低更新不了怎么办)

    苹果平板微信版本低登录不了怎么办(苹果平板微信版本低更新不了怎么办)

  • airpods反磁是什么(airpods1有没有反磁)

    airpods反磁是什么(airpods1有没有反磁)

  • ipad如何清理邮箱(ipad 怎么清楚垃圾内存)

    ipad如何清理邮箱(ipad 怎么清楚垃圾内存)

  • 淘宝追加评价怎么删除(淘宝追加评价怎么查看)

    淘宝追加评价怎么删除(淘宝追加评价怎么查看)

  • ios13电池百分比怎么设置(ios13电池百分比打开方法)

    ios13电池百分比怎么设置(ios13电池百分比打开方法)

  • 华为手机抖音连接不上网怎么办(华为手机抖音连麦有回音)

    华为手机抖音连接不上网怎么办(华为手机抖音连麦有回音)

  • soul现在怎么查看访客(soul怎么查用户)

    soul现在怎么查看访客(soul怎么查用户)

  • 荣耀20pro怎么解锁(荣耀20pro怎么解锁密码)

    荣耀20pro怎么解锁(荣耀20pro怎么解锁密码)

  • 小米空白卡怎么授权(小米空白卡怎么写入数据)

    小米空白卡怎么授权(小米空白卡怎么写入数据)

  • QQ自动回复咋设置(qq自动回复要怎么设置)

    QQ自动回复咋设置(qq自动回复要怎么设置)

  • 苹果手机出现蓝色方框怎么办(苹果手机出现蓝色移动框框咋办)

    苹果手机出现蓝色方框怎么办(苹果手机出现蓝色移动框框咋办)

  • qq怎么看以前的说说(qq怎么看以前的匿名消息)

    qq怎么看以前的说说(qq怎么看以前的匿名消息)

  • Win11怎么快速加密硬盘?Win11加密硬盘方法(win11 zen3)

    Win11怎么快速加密硬盘?Win11加密硬盘方法(win11 zen3)

  • ADSL MODEM安装好无线路由器后无法上网怎么办(安装adsl modem必须安装什么协议)

    ADSL MODEM安装好无线路由器后无法上网怎么办(安装adsl modem必须安装什么协议)

  • 文件错误0x80070522解决方法(文件错误会追究拟稿人吗)

    文件错误0x80070522解决方法(文件错误会追究拟稿人吗)

  • 利息可以抵税是什么意思
  • 房租租赁房产税由哪方缴纳
  • 集体不动产和动产包括
  • 个体工商户的个人所得税如何申报
  • 贸易公司委托加工买进和卖出东西不一样
  • 劳务派遣营改增政策
  • 员工的油费补贴怎么算
  • 即期外汇交易有幅度限制吗
  • 委托开发的软件产品即征即退
  • 结转上年度的企业所得税会计分录?
  • 代收水电气费加盟
  • 一般纳税人销售旧货
  • 资金账簿印花税滞纳金怎么算
  • 开票含税和不含税哪个划算
  • 二月份个税申报时间
  • 应收账款年末余额过大
  • 结转费用的会计分录
  • 应付款项余额
  • window10过期
  • win7如何取消关机
  • 出口退税操作步骤
  • 电脑自我诊断
  • qq登录界面的设计与实现
  • 抵偿债务会计处理
  • 微信小程序隐藏航班
  • 公司以知识产权出资纳税筹划
  • 应收账款净额可以是负数吗
  • 独立费用包括
  • 客户多付款入哪个科目
  • php设计模式及使用场景
  • 新准则预付账款计算公式
  • 网站变成灰色什么时候恢复
  • 残疾人就业保障金
  • 诉讼费发票丢失可以补开吗
  • java委托模式和代理模式
  • 个税出现负数是什么意思
  • 应收账款科目的期末余额
  • 上级补助收入是指事业单位从主管部门和上级单位取得的
  • 什么叫做公账对公账户
  • 技术人员工资计入生产成本吗
  • 结转利润分配的二级明细账户
  • 资本性支出项目管理
  • 初级会计现值的计算
  • 会计分录借贷怎么分视频教程
  • 开窗函数窗口范围
  • MySQL 5.7双主同步部分表的实现过程详解
  • mysql深入理解
  • window8开机
  • linux查看磁盘空间大小以及分配
  • linux 安装vs
  • linux忘记root密码怎么修改
  • centos6.5安装步骤
  • ati2sgag.exe进程安全吗 ati2sgag进程信息查询
  • mac怎么分区硬盘分区
  • 为大家详细介绍英语
  • win10预览版好吗
  • linux操作系统主要学什么
  • centos7.6有线连接
  • perform.exe是什么进程
  • ghost备份1678
  • win10开机显示recover
  • javascript抢票
  • 网页shell命令
  • windows批处理命令大全
  • vue组件生命周期执行顺序
  • PHP+jquery+ajax实现分页
  • 自动清除数据
  • Python文件处理
  • u3d transform
  • wordpress开发文档
  • jquery实现图片横向移动
  • bootstrap快速入门
  • python正则函数
  • python的argparse用法
  • 个体工商户票种核定金额应该填多少
  • 怎么打印电子社保
  • 请问各位专家金线吊乌龟有什么功效
  • 购房发票的发票代码是哪个
  • 办税人员怎么绑定电子税务系统
  • 餐饮票抵扣成本怎么算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设