vue v-model原理实现
Posted nimon-hugo
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue v-model原理实现相关的知识,希望对你有一定的参考价值。
v-model的实现原理:
基础用法:
v-model
本质上不过是语法糖,可以用 v-model 指令在表单 <input>
、<textarea>
及 <select>
元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。它负责监听用户的输入事件以更新数据,并对一些极端场景进行一些特殊处理。v-model
会忽略所有表单元素的 value
、checked
、selected
特性的初始值而总是将 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原理实现的主要内容,如果未能解决你的问题,请参考以下文章