Vue 中 this.$emit(“update:xx“,value) 和 :xx.sync 实现同步数据的做法

在 Vue 2.x 中,this.$emit('update:xx', value)xx.sync 都是用来实现父子组件之间的数据同步的方式,它们背后的工作原理有些相似,但语法上有所不同。让我们逐个详细解释这两者的使用方式。

xx.sync(语法糖)

xx.sync 是 Vue 提供的一种语法糖,用来简化子组件和父组件之间数据同步的操作。它的工作原理是自动化地监听 update:xx 事件并更新父组件的数据。

实际上,xx.syncv-bindv-on 的组合,背后也调用了 this.$emit('update:xx', value)

使用步骤:

  1. 父组件 :使用 xx.sync 来绑定数据。
  2. 子组件 :通过 $emit('update:xx', value) 来更新父组件的数据。

示例:

父组件:
vue 复制代码
<template>
  <div>
    <child-component :xx.sync="parentData" />
    <p>父组件数据: {{ parentData }}</p>
  </div>
</template>

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

export default {
  components: {
    ChildComponent
  },
  data() {
    return {
      parentData: '初始值'
    };
  }
};
</script>
子组件:
vue 复制代码
<template>
  <div>
    <button @click="updateParentData">更新父组件数据</button>
  </div>
</template>

<script>
export default {
  props: {
    xx: String
  },
  methods: {
    updateParentData() {
      // 通过 $emit 向父组件发送更新事件
      this.$emit('update:xx', '新数据');
    }
  }
};
</script>

解释

  • 父组件 :使用 :xx.sync="parentData" 自动将 parentData 与子组件的 xx prop 绑定,并且当 xx 更新时,parentData 会自动同步更新。

  • 子组件 :当子组件需要更新数据时,通过 this.$emit('update:xx', '新数据') 向父组件发送 update:xx 事件。

  • this.$emit('update:xx', value) 是 Vue 2.x 中标准的父子组件数据同步方式,它通过自定义事件机制来实现数据更新。这种方式需要显式地绑定事件监听,并在子组件中触发更新。

  • xx.sync 是 Vue 2.x 提供的语法糖,简化了数据同步的操作。它背后其实是自动化了 $emit('update:xx', value) 过程,适用于较简单的双向绑定场景。

相关推荐
迷路的小绅士5 分钟前
常见网络安全攻击类型深度剖析(四):跨站脚本攻击(XSS)——分类、漏洞利用与前端安全防护
前端·安全·web安全
前端snow13 分钟前
前端全栈第一课:用typeorm向数据库添加数据
前端
小希爸爸14 分钟前
3、中医基础入门和养生
前端·javascript·后端
摆烂工程师30 分钟前
ChatGPT免费用户可以使用Deep Research啦!并且o3、o4-mini的可使用次数翻倍!
前端·后端·程序员
狂炫一碗大米饭31 分钟前
作为前端你不得不知道的浏览器相关知识1🚀
前端
天天扭码39 分钟前
🔥 别再用 class 了!JS 原型链才是 YYDS
前端·javascript·面试
GISer_Jinger44 分钟前
📢《告别手动抓狂!Trae国际版+BrowserTools MCP 实现前端错误调试自动化》🚀
前端
前端大白话1 小时前
震惊!90%前端工程师都踩过的坑!computed属性vs methods到底该怎么选?一文揭秘高效开发密码
前端·vue.js·设计模式
一天睡25小时1 小时前
React与Vue表单的对比差异
前端·javascript
作曲家种太阳1 小时前
第七章 响应式的 watch 实现【手摸手带你实现一个vue3】
前端