.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)"
>
相关推荐
Apifox1 分钟前
Apifox 6 月更新|Apifox CLI 全面升级、导入导出优化、OAuth 2.0 支持自动刷新令牌
前端·后端·测试
CodingSpace12 分钟前
TypeScript 装饰器
前端
宸翰15 分钟前
解决 uni-app App 端 vue-i18n 占位符丢失:封装跨端可用的 tf 格式化方法
前端·vue.js·uni-app
systemPro21 分钟前
光储充系统数据流全解析:PV / ESS / GRID 数据怎么流转,线损怎么算
前端
用户2986985301438 分钟前
在 React 中使用 JavaScript 将 Excel 转换为 PDF
javascript·react.js·webassembly
古茗前端团队2 小时前
急招!前端|测试|后端|产品(名额多,速来)
前端·后端·架构
Lsx_3 小时前
不只是 Prompt:用 Superpowers Skill 给 AI 编程装上工程化工作流
前端·ai编程·claude
用户938515635073 小时前
从 Prompt 到 Harness:AI 工程化的三年跃迁与实战解码
javascript·人工智能
小碗细面3 小时前
前端 Prompt 工程实战:如何搭建场景化 Prompt 库
前端·ai编程
阿瑞IT3 小时前
2026年 AI Agent 生产化落地全景:四大高频故障根因分析与工程解法
前端