【vue】vue中.sync修饰符如何使用--详细代码对比

.sync修饰符作用

.sync修饰符是一个语法糖,可以简化父子组件通信操作,当子组件想改变父组件数值时,父组件只需要使用**.sync** 修饰符,子组件使用props 接收属性,再使用**this.$emit('update:属性', 值);**就可以实现子组件更新父组件数据的操作。

以下将用el-dialog例子展示传统父子通信及使用.sync修饰符后的父子通信区别:

传统父子通信

javascript 复制代码
//父组件
<template>
  <div>
    <button @click="openDialog">打开对话框</button>
<!--给子组件传递dialogVisible属性-->
    <ChildDialog :dialogVisible="dialogVisible" @updateDialogVisible="handleDialogVisibleChange"></ChildDialog>
  </div>
</template>

<script>
import ChildDialog from './ChildDialog.vue';

export default {
  components: {
    ChildDialog
  },
  data() {
    return {
      dialogVisible: false
    };
  },
  methods: {
    openDialog() {
      this.dialogVisible = true;
    },
//收到子组件传来的新值,更新dialogVisible 
    handleDialogVisibleChange(newVisible) {
      this.dialogVisible = newVisible;
    }
  }
};
</script>

//子组件
<template>
  <el-dialog :visible="dialogVisible" @close="closeDialog">
    <span>这是对话框内容</span>
  </el-dialog>
</template>

<script>
export default {
  props: {
    dialogVisible: {
      type: Boolean
    }
  },
  methods: {
    closeDialog() {
//自定义监听事件,将新值传给父组件
      this.$emit('updateDialogVisible', false);
    }
  }
};
</script>

.sync修饰符父子通信

javascript 复制代码
//父组件
<template>
  <div>
    <button @click="dialogVisible = true">打开对话框</button>
<!--父组件不需要再绑定监听事件获取新值再赋给dialogVisible
    .sync修饰符可以自动完成数据更新操作,更简洁-->
    <ChildDialog :dialogVisible.sync="dialogVisible"></ChildDialog>
  </div>
</template>

<script>
import ChildDialog from './ChildDialog.vue';

export default {
  components: {
    ChildDialog
  },
  data() {
    return {
      dialogVisible: false
    };
  }
};
</script>

//子组件
<template>
  <el-dialog :visible="dialogVisible" @close="closeDialog">
    <span>这是对话框内容</span>
  </el-dialog>
  </template>

<script>
export default {
  props: {
    dialogVisible: {
      type: Boolean
    }
  },
  methods: {
    closeDialog() {
//告诉父组件哪个属性更新并且传新值
      this.$emit('update:dialogVisible', false);
    }
  }
};
</script>

欢迎指正!

相关推荐
2401_859049082 分钟前
git submodule update --init --recursive无法拉取解决
前端·chrome·git
这是个栗子21 分钟前
【Vue代码分析】前端动态路由传参与可选参数标记:实现“添加/查看”模式的灵活路由配置
前端·javascript·vue.js
刘一说29 分钟前
Vue 动态路由参数丢失问题详解:为什么 `:id` 拿不到值?
前端·javascript·vue.js
熊猫钓鱼>_>1 小时前
动态网站发布部署核心问题详解
前端·nginx·容器化·网页开发·云服务器·静态部署
方也_arkling1 小时前
elementPlus按需导入配置
前端·javascript·vue.js
爱吃大芒果1 小时前
Flutter for OpenHarmony 实战: mango_shop 资源文件管理与鸿蒙适配
javascript·flutter·harmonyos
我的xiaodoujiao1 小时前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 44--将自动化测试结果自动推送至钉钉工作群聊
前端·python·测试工具·ui·pytest
沛沛老爹1 小时前
Web开发者转型AI:多模态Agent视频分析技能开发实战
前端·人工智能·音视频
David凉宸1 小时前
vue2与vue3的差异在哪里?
前端·javascript·vue.js
Irene19911 小时前
JavaScript字符串转数字方法总结
javascript·隐式转换