zoukankan      html  css  js  c++  java
  • v-model的实现原理

    基础用法

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

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

      • text 和 textarea 元素使用 value 属性和 input 事件;
      • checkbox 和 radio 使用 checked 属性和 change 事件;
      • select 字段将 value 作为 prop 并将 change 作为事件。

    实现原理

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

      • v-bind:绑定响应式数据

      • 触发oninput 事件并传递数据

    • 举例如下:

      <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;
      
  • 相关阅读:
    练字的感悟
    关于简单
    全都是泡沫
    跟着电影环游世界
    12.8《印度之行》
    11.21派生类对基类的访问
    Linux,begin
    如何利用google
    回调函数
    原型对象
  • 原文地址:https://www.cnblogs.com/wangchangli/p/11328781.html
Copyright © 2011-2022 走看看