码迷,mamicode.com
首页 > 其他好文 > 详细

vue v-model原理实现

时间:2020-05-25 15:17:17      阅读:108      评论:0      收藏:0      [点我收藏+]

标签:场景   控件   来源   实例   ted   举例   model   script   java   

v-model的实现原理:

基础用法:

v-model 本质上不过是语法糖,可以用 v-model 指令在表单 <input><textarea> 及 <select> 元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。它负责监听用户的输入事件以更新数据,并对一些极端场景进行一些特殊处理。v-model 会忽略所有表单元素的 valuecheckedselected 特性的初始值而总是将 Vue 实例的数据作为数据来源。你应该通过 JavaScript 在组件的 data 选项中声明初始值。

v-model 在内部为不同的输入元素使用不同的属性并抛出不同的事件:

1、text 和 textarea 元素使用 value 属性和 input 事件;

2、checkbox 和 radio 使用 checked 属性和 change 事件;

3、select 字段将 value 作为 prop 并将 change 作为事件。

实现原理

1、v-model只不过是一个语法糖而已,真正的实现靠的还是

1)v-bind:绑定响应式数据

2)触发oninput 事件并传递数据

3)举例如下:

<input v-model="sth" />
//  等同于
<input :value="sth" @input="sth = $event.target.value" /> //自html5开始,input每次输入都会触发oninput事件,所以输入时input的内容会绑定到sth中,于是sth的值就被改变;
//$event 指代当前触发的事件对象;
//$event.target 指代当前触发的事件对象的dom;
//$event.target.value 就是当前dom的value值;
//在@input方法中,value => sth;
//在:value中,sth => value;

总结:数据双向绑定其实就是调用对应组件的事件处理函数来执行实现数据的同步更新;

vue v-model原理实现

标签:场景   控件   来源   实例   ted   举例   model   script   java   

原文地址:https://www.cnblogs.com/nimon-hugo/p/12956772.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!