vue3 父子组件传参

我现在的需求是 在增加编辑产业的时候 要传递楼栋id,以及楼层的id 我的实现方法是添加两个按钮 点击弹出楼栋以及楼层的dialog 在这个dialog里面可以选择单条楼栋以及单条楼层

现在按钮以及楼栋的弹窗写完了 楼栋的弹窗点击确定 要返回选中的数据

实现的方法是通过emit

复制代码
//子组件
const emit = defineEmits(['submit'])
const submit = () => {
  emit('submit', currentRow.value);
  close()
}
//父组件
 <door-info-dialog ref="doorInfoDialogRef" @submit="submitDoor"></door-info-dialog>
 const submitDoor=(val:any)=>{ 
   //通过val可以拿到子组件的传来的数据
   state.form.buildId=val.id
   state.form.buildName=val.buildName 
}

现在拿到了楼栋的id 要将这个id传递给floorDialog 来根据楼栋id查找楼层

传递的方法是通过pops

复制代码
//父组件
<floor-info-dialog ref="floorInfoDialogRef" :buildId="state.form.buildId" @submit="submitFloor" > </floor-info-dialog>
//子组件
const props = defineProps<{
    buildId: string | number; // 适当设定为 `string` 或 `number`
}>();
const open = () => {
    console.log('open');
    console.log('props',props.buildId);
    state.visible = true;
    props.buildId &&getFloorsFunc(props.buildId); // 在打开时调用以获取数据
    console.log('run open');
}

defineExpose({
    open
})
相关推荐
lovepenny4 分钟前
Failed to resolve entry for package "js-demo-tools". The package may have ......
前端·npm
超凌12 分钟前
threejs 创建了10w条THREE.Line,销毁数据,等待了10秒
前端
车厘小团子30 分钟前
🎨 前端多主题最佳实践:用 Less Map + generate-css 打造自动化主题系统
前端·架构·less
芒果12534 分钟前
SVG图片通过img引入修改颜色
前端
海云前端11 小时前
前端面试ai对话聊天通信怎么实现?面试实际经验
前端
一枚前端小能手1 小时前
🔧 半夜被Bug叫醒的痛苦,错误监控帮你早发现
前端
Juchecar1 小时前
Vue 3 单页应用Router路由跳转示例
前端
这人是玩数学的1 小时前
在 Cursor 中规范化生成 UI 稿实践
前端·ai编程·cursor
UncleKyrie1 小时前
🎨 市面上主流 Figma to Code MCP 对比
前端
李明卫杭州1 小时前
CSS `clamp()` 函数详解
javascript