标签:场景 控件 来源 实例 ted 举例 model script java
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
作为事件。
<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;
总结:数据双向绑定其实就是调用对应组件的事件处理函数来执行实现数据的同步更新;
标签:场景 控件 来源 实例 ted 举例 model script java
原文地址:https://www.cnblogs.com/nimon-hugo/p/12956772.html