vue v-model原理实现

Posted nimon-hugo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue v-model原理实现相关的知识,希望对你有一定的参考价值。

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原理实现的主要内容,如果未能解决你的问题,请参考以下文章

vue v-model 的实现原理

v-model的实现原理

vue v-model原理实现

vue v-model原理实现

使用JavaScript编写vue指令v-model,v-model原理实现

Vue中v-model基本使用