vue3 自定义 v-model(无参数和带参数)【setup版】(两种方案)

vue2 自定义 v-model 详见 https://sunshinehu.blog.csdn.net/article/details/136942322

vue3 自定义 v-model【方案一】

子组件 Child.vue

<script setup>
defineProps(["modelValue"]);
const emits = defineEmits();
</script>

<template>
  <input
    type="text"
    :value="modelValue"
    @input="emits('update:modelValue', $event.target.value)"
  />
</template>

父组件

<script setup>
import { ref } from "vue";
import Child from "./Child.vue";

const msg = ref("");
</script>

<template>
  <div>
    {{ msg }}
    <Child v-model="msg" />
  </div>
</template>

技术要点

vue3 中,若 v-model 未配置参数,则

  • 父组件给子组件传入了名为 modelValue 的 prop
  • 父组件监听了子组件的自定义事件 update:modelValue

v-model 带参数

vue3 支持多个v-model,且可带参数

父组件

<script setup>
import { ref } from "vue";
import Child from "./Child.vue";

const title = ref("");
const msg = ref("");
</script>

<template>
  <div>
    <p>{{ title }}</p>
    <p>{{ msg }}</p>
    <Child v-model:title="title" v-model:msg="msg" />
  </div>
</template>

子组件

<script setup>
defineProps(["title", "msg"]);
const emits = defineEmits(["update:title", "update:msg"]);
</script>

<template>
  <input
    type="text"
    :value="title"
    @input="emits('update:title', $event.target.value)"
  />

  <input
    type="text"
    :value="msg"
    @input="emits('update:msg', $event.target.value)"
  />
</template>

vue3 自定义 v-model【方案二】推荐

<!-- 组合式 API vue3.4+ -->
<script setup>
const model = defineModel()
</script>

<template>
	<input v-model="model">
</template>

defineModel() 返回的值是一个 ref

  • 它的 .value 和父组件的 v-model 的值同步
  • 当它被子组件变更时,会触发父组件绑定的值一起更新

v-model 带参数

以参数 “title” 为例

<!-- 组合式 API vue3.4+ -->
<script setup>
const title = defineModel('title')
</script>

<template>
  <input type="text" v-model="title" />
</template>

父组件

<MyComponent v-model:title="bookTitle" />

相关推荐

  1. vue3的组件间的v-model参数

    2024-06-09 14:14:03       15 阅读
  2. vue3定义组件使用v-model

    2024-06-09 14:14:03       13 阅读
  3. vue3利用定义事件v-model实现父子传参

    2024-06-09 14:14:03       37 阅读
  4. spark 定义外部配置参数的三方式

    2024-06-09 14:14:03       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-09 14:14:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-09 14:14:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-09 14:14:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-09 14:14:03       18 阅读

热门阅读

  1. 力扣2799.统计完全子数组的数目

    2024-06-09 14:14:03       11 阅读
  2. lua中大数相乘的问题

    2024-06-09 14:14:03       10 阅读
  3. LeetCode 第401场周赛个人题解

    2024-06-09 14:14:03       12 阅读
  4. 二叉树的统一迭代法-前序中序后序-力扣

    2024-06-09 14:14:03       12 阅读