zoukankan      html  css  js  c++  java
  • 如何自定义组件的v-model

    如果说要MyInput.vue组件,和父组件App.vue中的name联动

    1、MyInput.vue

    <template>
      <div>
        <input type="textarea" :value='value' @input='(e)=>$emit("input",e.target.value)'>
      </div>
    </template>
    <script>
    export default {
      props: ['value']
    }
    </script>

    2、App.vue

    <MyInput :value="name" @input='name=$event' />

      此处,可以使用v-model='name'替换 :value='name' @input='name=$event',即:

    <MyInput v-model="name" />

    那如果要定义一个MyCheckbox组件呢?

    1、MyCheckbox.vue

    <template>
      <div>
        <input type="checkbox" :checked='checked' @change='(e)=>$emit("change",e.target.checked)'>选项
      </div>
    </template>
    <script>
    export default {
      props: ['checked']
    }
    </script>

    2、App.vue

    <MyCheckbox :checked='checked' @change="checked=$event" />

      如果此处要想使用v-model去替换:checked='checked' @change="checked=$event",即:

    <MyCheckbox v-model="checked" />

      那么此时是无效的,因为v-model的默认属性是value,默认的事件是input,需要在子组件内去自定义v-model的属性名和事件名

    3、MyCheckbox.vue

      model: {
        prop: 'checked',
        event: 'change'
      }

      此时,<MyCheckbox v-model="checked" />上的v-mode绑定的属性为checked,事件为change

  • 相关阅读:
    c# 设计模式(一) 工厂模式
    微信开发
    一款非常好用的 Windows 服务开发框架,开源项目Topshelf
    基础语法
    C++环境设置
    c++简介
    使用查询分析器和SQLCMD分别登录远程的SQL2005的1434端口
    ps-如何去水印
    html/css/js-横向滚动条的实现
    java中如何给控件设置颜色
  • 原文地址:https://www.cnblogs.com/wuqilang/p/14875864.html
Copyright © 2011-2022 走看看