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;
      
  • 相关阅读:
    MT4编程初级手册
    导出oracle序列
    Win10下用Anaconda安装TensorFlow
    06-python opencv 使用摄像头捕获视频并显示
    python @修饰符的几种用法
    Ubuntu 16.04 安装 PyCharm
    Python判断变量的数据类型的两种方法
    上海地图
    kindle看扫描版pdf的解决办法
    查看已安装tensorflow版本
  • 原文地址:https://www.cnblogs.com/wangchangli/p/11328781.html
Copyright © 2011-2022 走看看