自定义组件使用v-model 实现双向数据绑定

在 Vue.js 中,如果你想在一个自定义组件中使用 v-model 来实现双向数据绑定,你需要遵循一些特定的步骤。v-model 实际上是以下两个属性的语法糖:

  1. 一个名为 value 的 prop,用于接收父组件传递的数据。
  2. 一个名为 input 的事件,当子组件中的值发生变化时触发,并将新的值作为参数传递给该事件。

基本实现

假设你有一个简单的输入框组件 CustomInput,你可以这样来实现 v-model

子组件 (CustomInput.vue)
vue 复制代码
<template>
  <input
    :value="value"
    @input="$emit('input', $event.target.value)"
  >
</template>

<script>
export default {
  props: {
    // 定义 value 为必需的 prop
    value: {
      type: String,
      required: true
    }
  }
}
</script>

在这个例子中,value 是从父组件传入的 prop,而 @input 事件处理器会触发 $emit('input', ...),将新的值发送回父组件。

父组件
vue 复制代码
<template>
  <div>
    <custom-input v-model="message"></custom-input>
    <p>{{ message }}</p>
  </div>
</template>

<script>
import CustomInput from './CustomInput.vue';

export default {
  components: {
    CustomInput
  },
  data() {
    return {
      message: ''
    };
  }
}
</script>

这里,v-model 绑定了 messageCustomInput 组件上。每当用户在输入框中输入内容时,CustomInput 会通过 @input 事件更新 message

自定义 v-model 的模型名称

如果你不想使用默认的 valueinput,你可以通过 model 选项来自定义它们:

子组件 (CustomInput.vue) 使用自定义模型
vue 复制代码
<template>
  <input
    :value="customValue"
    @change="$emit('update:customValue', $event.target.value)"
  >
</template>

<script>
export default {
  props: {
    customValue: {
      type: String,
      required: true
    }
  }
}
</script>
父组件
vue 复制代码
<template>
  <div>
    <custom-input v-model:customValue="message"></custom-input>
    <p>{{ message }}</p>
  </div>
</template>

<script>
import CustomInput from './CustomInput.vue';

export default {
  components: {
    CustomInput
  },
  data() {
    return {
      message: ''
    };
  }
}
</script>

在这个例子中,我们使用了 v-model:customValue 来指定使用的 prop 名称和事件名称。注意,在子组件中,事件名需要是 update:customPropName 的形式。

以上就是如何在自定义组件中实现 v-model 的方法。通过这种方式,你可以轻松地在任何自定义组件中实现双向数据绑定。

相关推荐
接着奏乐接着舞14 小时前
sse 两种调用方式
前端·javascript·vue.js
不会敲代码119 小时前
手写 Mini React:从 JSX 到虚拟 DOM 再到 render,搞懂 React 底层原理
前端·javascript·react.js
kyriewen20 小时前
你的代码仓库变成“毛线团”了?Monorepo 用 Turborepo 拆成“乐高积木”
前端·javascript·面试
openKaka_1 天前
createRoot 到底创建了什么:FiberRootNode 和 HostRootFiber 的初始化过程
前端·javascript·react.js
阿豪只会阿巴1 天前
【没事学点啥】TurboBlog轻量级个人博客项目——项目介绍
javascript·python·django·html
刀法如飞1 天前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
_风满楼1 天前
TDD实战-会议室冲突检测的红绿重构循环
前端·javascript·算法
Rkgua1 天前
JS中的惰性函数基本介绍
前端·javascript
客场消音器1 天前
我用两周半 Vibe Coding 做了一个前额叶训练的微信小程序
前端·javascript·后端
azhou的代码园1 天前
基于SpringBoot+Vue的家教小程序
vue.js·spring boot·小程序·毕业设计·家教小程序