首页 > 其他 > 详细

如何自定义组件的v-model

时间:2021-06-12 01:29:20      阅读:23      评论:0      收藏:0      [点我收藏+]

如果说要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

 

如何自定义组件的v-model

原文:https://www.cnblogs.com/wuqilang/p/14875864.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!