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;
      
  • 相关阅读:
    React获取文本框的值
    Ant-design正则判断_未输入用户名和密码点击按钮提示输入
    Redux的简单使用
    React后台管理系统 路由守卫
    移动端如何定义字体font-family
    meta基础知识
    闭包
    前端优化
    jacaScript数组
    分享一款强大的图片查看器插件,手机PC 通吃,功能超级齐全!
  • 原文地址:https://www.cnblogs.com/wangchangli/p/11328781.html
Copyright © 2011-2022 走看看