.sync使用

1..sync的常规用法

父组件中:

javascript 复制代码
<!-- 父组件 -->
<custom-dialog :visible.sync="dialogVisible">
  内容区域
</custom-dialog>
这行代码实际上会被 Vue 编译为:
javascript 复制代码
<custom-dialog 
  :visible="dialogVisible"
  @update:visible="val => dialogVisible = val"
>

子组件中:

javascript 复制代码
<script>
export default {
  props: ['visible'],
  methods: {
    close() {
      // 子组件通过触发特定事件来更新父组件数据
      this.$emit('update:visible', false)
    }
  }
}
</script>

2.封装多层组件时,需要拆解.sync,否则打开一次后报错就无法打开第二次

javascript 复制代码
<!-- 中间层组件 -->
<template>
  <div class="wrapper">
    <!-- 1. 显式绑定 prop -->
    <!-- 2. 显式监听事件并向上转发 -->
    <custom-dialog 
      :visible="visible"
      @update:visible="val => $emit('update:visible', val)"
    >
      <slot></slot>
    </custom-dialog>
  </div>
</template>

<script>
export default {
  props: {
    // 必须显式声明接收父组件传来的 visible
    visible: {
      type: Boolean,
      default: false
    }
  }
}
</script>

或简写形式

javascript 复制代码
<custom-dialog 
  :visible="visible"
  @update:visible="$emit('update:visible', $event)"
>
相关推荐
蜡台1 分钟前
Node 版本管理器NVM 安装配置和使用
前端·javascript·vue.js·node·nvm
狂奔蜗牛飙车4 分钟前
Day3:HTML5 基础标签:h1-h6、p、hr、br、a、img
前端·html·html5·html常用标签的使用方法
木斯佳12 分钟前
前端八股文面经大全:腾讯前端暑期提前批一、二、三面面经(下)(2026-03-04)·面经深度解析
前端
bluceli21 分钟前
前端国际化(i18n)实战指南:构建多语言应用的完整方案
前端
hh随便起个名32 分钟前
React组件通信
前端·react.js·前端框架
前端 贾公子34 分钟前
vite-plugin-eruda-pro 在vite中使用eruda
前端
Jackson__1 小时前
Agent Skill 和 Rules 有什么区别?
前端·agent·ai编程
不要卷鸿蒙啊1 小时前
【鸿蒙开发】HMRouter一款和好用的管理路由三方工具
前端·harmonyos
李剑一1 小时前
数字孪生大屏必看:Cesium 3D 模型选中交互,3 种高亮效果拿来就用!
前端·vue.js·cesium
奶昔不会射手2 小时前
自定义vue3函数式弹窗
前端·javascript·css