zoukankan      html  css  js  c++  java
  • 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;

    总结:数据双向绑定其实就是调用对应组件的事件处理函数来执行实现数据的同步更新;

  • 相关阅读:
    Yum安装MySQL
    Java最小化镜像制作
    Docker CE安装
    每月最后一周的周六晚上21:00执行任务-crontab
    每10秒执行定时任务-crontab
    可复制领导力-回顾收录
    逻辑数据库设计
    5e赋能核心文化
    python 学习自学
    德鲁克的“五项主要习惯”
  • 原文地址:https://www.cnblogs.com/nimon-hugo/p/12956772.html
Copyright © 2011-2022 走看看