位置: 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获取值的几种方法)

  • 打印机共享无线网络怎么设置(打印机共享无法打印)(打印机共享无线怎么连接)

    打印机共享无线网络怎么设置(打印机共享无法打印)(打印机共享无线怎么连接)

  • switch手柄可以连电脑吗(switch手柄可以连蓝牙吗)

    switch手柄可以连电脑吗(switch手柄可以连蓝牙吗)

  • 金立手机卡顿反应慢怎么办(金立手机为什么卡的厉害)

    金立手机卡顿反应慢怎么办(金立手机为什么卡的厉害)

  • 微博被屏蔽的人知道自己被屏蔽了吗(微博被屏蔽的人还能在我的发表的评论下评论我吗)

    微博被屏蔽的人知道自己被屏蔽了吗(微博被屏蔽的人还能在我的发表的评论下评论我吗)

  • 支持ddr4的主板有哪些(支持DDR4的主板支持什么CPU)

    支持ddr4的主板有哪些(支持DDR4的主板支持什么CPU)

  • scltl00华为是什么型号(华为sclcl00是啥型号)

    scltl00华为是什么型号(华为sclcl00是啥型号)

  • 小度链接不上网络怎么办(小度连接不上网)

    小度链接不上网络怎么办(小度连接不上网)

  • qq小海螺标志是什么(qq海螺标识怎么点亮)

    qq小海螺标志是什么(qq海螺标识怎么点亮)

  • 什么是电子版文件(什么是电子版文字文档)

    什么是电子版文件(什么是电子版文字文档)

  • 苹果两网是什么意思(苹果两网啥意思)

    苹果两网是什么意思(苹果两网啥意思)

  • 红米k305g支持扩容吗(红米k30支持扩容吗)

    红米k305g支持扩容吗(红米k30支持扩容吗)

  • 第二代计算机的主要部件是由什么构成的(第二代计算机的主要元件是什么)

    第二代计算机的主要部件是由什么构成的(第二代计算机的主要元件是什么)

  • usb floppy 什么意思(usb floppy device什么意思)

    usb floppy 什么意思(usb floppy device什么意思)

  • 安装包怎么安装(系统安装包怎么安装)

    安装包怎么安装(系统安装包怎么安装)

  • 手机刷机后内置的软件怎么卸载(手机刷机后内置卡怎么办)

    手机刷机后内置的软件怎么卸载(手机刷机后内置卡怎么办)

  • 通常所说的cpu是指(常说的cpu指的是)

    通常所说的cpu是指(常说的cpu指的是)

  • 抖音现在怎么没有动态了(抖音现在怎么没有美体功能了)

    抖音现在怎么没有动态了(抖音现在怎么没有美体功能了)

  • 网页的视频能加速么(网页的视频能加字幕吗)

    网页的视频能加速么(网页的视频能加字幕吗)

  • iqooneo是否支持nfc(vivoiqooneo支持nfc吗)

    iqooneo是否支持nfc(vivoiqooneo支持nfc吗)

  • 用友t3反结账怎么操作(用友t3反结算)

    用友t3反结账怎么操作(用友t3反结算)

  • 为什么qq安装不了(为什么QQ安装不了应用)

    为什么qq安装不了(为什么QQ安装不了应用)

  • 华为p10热点为何共享不了(华为热点为什么不可上网)

    华为p10热点为何共享不了(华为热点为什么不可上网)

  • xr支持动态壁纸吗(xr动态壁纸按压没反应)

    xr支持动态壁纸吗(xr动态壁纸按压没反应)

  • 猎豹浏览器如何设置兼容模式(猎豹浏览器如何清除缓存)

    猎豹浏览器如何设置兼容模式(猎豹浏览器如何清除缓存)

  • 淘宝怎么上传宝贝(淘宝怎么上传宝贝主图视频)

    淘宝怎么上传宝贝(淘宝怎么上传宝贝主图视频)

  • fwhois命令  查找并显示用户信息(find命令详解查找文件)

    fwhois命令 查找并显示用户信息(find命令详解查找文件)

  • Python中的描述符(python描述器有什么用)

    Python中的描述符(python描述器有什么用)

  • 非营利组织营利了怎么办
  • 应交税费课程
  • 工会经费计税依据包括社保吗
  • 税务师财务与会计难不难
  • 投标保证金保险怎么买
  • 增值税计入当期损益吗?
  • 房地产中心
  • 应预缴的增值税
  • 融资租赁方式租出的固定资产
  • 资产减值损失负数是好是坏
  • 确认社保局工伤赔款会计分录
  • 装修费属于劳务费吗
  • 个人年终奖如何交税
  • 自然人个税起征点2019税率表
  • 合并报表内部往来核对不上
  • 用友u8计提企业所得税
  • 小规模纳税人专票如何申报
  • 简易征收发票认证了之后怎么处理
  • 专项应付款与补助的区别
  • 鸿蒙系统怎么开发
  • 旅游开发企业会计账务处理
  • 收到工会经费怎样做账
  • 公司费用高好还是低好
  • 冲回坏账
  • 企业接到银行收账通知
  • vscode国内镜像
  • php数组函数输出《咏雪》里有多少"片"字
  • 产供销一体化什么意思
  • win10设置待机时间长怎么在哪里设置
  • 固定资产盘盈会影响所有者权益吗
  • 如何设置长期有效的群二维码安卓手机
  • php对接mysql
  • 计提工会经费会计账务处理
  • 减免税费是几级科目
  • 前端的基础知识
  • php实现查询功能
  • 在报税显示缺少税种信息
  • php提交表单数据有哪几种方法
  • this.emit('input')
  • vuex五个核心概念
  • python pyecharts
  • 苹果系统推送通知
  • css中权重值是什么意思
  • 在建工程的前期工程
  • 一般纳税人怎么转为小规模纳税人
  • 代扣代缴手续费返还账务处理
  • 有赞微小店认证麻烦
  • 自然人独资和个人独资是一样的吗
  • sql server数据
  • db2pd 命令
  • 会计新准则2020
  • 差旅费补助无发票的文件依据
  • 文化事业建设费减免政策
  • 金融企业应当按照交易或事项的实质和经济现实
  • 企业如何进行促销
  • 自建的固定资产折旧计入哪里
  • 主营业务成本记借方还是贷方
  • 国家资产负债表
  • 低值易耗品五五摊销法报废
  • win2008组策略
  • 苹果电脑dock栏是什么意思
  • freebsd 配置ip
  • 此windows副本不是正版黑屏
  • mac的itunes怎么下载歌曲
  • win10如何关闭windows
  • 联想y485p升级无线网卡
  • win8系统网络设置在哪里
  • 如何找回windows删除的文件
  • 如何显示文件后缀名
  • js模拟登录网站
  • jquery源码是什么水平
  • easyui datagrid loader
  • css使用教程
  • content provider
  • linux中wget命令出现错误
  • JavaScript中length属性的使用方法
  • python写脚本教程
  • 契税减免优惠政策2023年最新
  • 消费税是由消费者完全负担的税种
  • 北京税务局待遇有住宿吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设