vue3使用v-model控制子组件进行双向数据绑定

vue2写法:

中父组件调用子组件:

<child :isShow.sync="isShow" v-show="isShow"/>

子组件想要消失, 在子组件写:

this.$emit("update:isShow",false);

具体代码就不粘贴了

vue3写法:

父组件核心代码:

v-model:a="xxx"

子组件核心代码:

defineProps({

a: 数据类型, // 父页面传递的数据

});

interface IEmits {

(e: 'update:a', arg1: 数据类型): void;

}

const emits = defineEmits<IEmits>();

调用父组件的方法:

emits("update:isShow", false);

使用示例:

注意: v-model:isShow="isShow" 如果拆开写就是 @update:isShow="bol=>isShow=bol" :isShow="isShow"

父组件代码如下:

复制代码
<script setup>
import { ref, defineAsyncComponent } from 'vue'

// 异步组件
const ChildA = defineAsyncComponent(() => import('./components/Test.vue'));

const isShow = ref(false);
const show = () => {
  isShow.value = true
}
</script>

<template>
  <input type="button" value="我是父组件中的按钮, 让子组件出现" @click="show">
  <!-- v-model:isShow="isShow"=> @update:isShow="bol=>isShow=bol" :isShow="isShow" -->
  <ChildA v-model:isShow="isShow" />
</template>

<style scoped>
</style>

子组件逻辑:

因为 v-model:isShow="isShow" 如果拆开写就是 @update:isShow="bol=>isShow=bol" :isShow="isShow"

所以:

defineProps({

isShow: Boolean

});

const hide = () => {

emits("update:isShow", false);

}

子组件代码如下:

复制代码
<script setup lang="ts">
// 父组件传数据 v-model:isShow="isShow"
// v-model:isShow="isShow"=> @update:isShow="bol=>isShow=bol" :isShow="isShow"
defineProps({
  isShow: Boolean
});

interface IEmits {
  (e: 'update:isShow', arg1: Boolean): void;
}
const emits = defineEmits<IEmits>();

const hide = () => { // 因为父页面传过来的方法相当于是bol=>isShow=bol, 所以传false就会消失
  emits("update:isShow", false);
}
</script>

<template>
  <div v-show="isShow">
    <button @click="hide">我是子组件,点我消失</button>
  </div>
</template>

<style scoped>
button {
  margin: 10px;
}
</style>
相关推荐
墨鱼鱼4 分钟前
【征文计划】Rokid JSAR 实践指南:打造沉浸式 "声动空间盒" 交互体验
前端
渣哥4 分钟前
多环境配置利器:@Profile 在 Spring 项目中的实战价值
javascript·后端·面试
携欢7 分钟前
Portswigger靶场之Exploiting a mass assignment vulnerability通关秘籍
前端·安全
什么芋泥香蕉33015 分钟前
比 Manus 还好用?这款国产 AI,让 Python 小白也能玩转编程
前端·后端
为java加瓦15 分钟前
前端学AI:如何写好提示词(prompt)
前端·人工智能·prompt
U.2 SSD22 分钟前
Echart仪表盘示例
javascript·echarts
qq_18417767723 分钟前
前端自动部署项目到服务器
服务器·前端·javascript
非凡ghost25 分钟前
猫眼浏览器(Chrome内核增强版浏览器)官方便携版
前端·网络·chrome·windows·软件需求
Never_Satisfied30 分钟前
在JavaScript / HTML / Node.js中,post方式的Content-Type属性的text的三种编码
javascript·node.js·html
C2X39 分钟前
Vue3.0 学习总结
前端