Vue中的组件通信方式及应用场景

简介: Vue中的组件通信方式及应用场景

在Vue中,组件通信有以下几种方式:

  1. Props / $emit:父组件通过给子组件传递props属性,子组件通过$emit事件将数据传递给父组件。适用于父组件向子组件传递数据。
  2. 自定义事件:父组件通过$on监听子组件触发的事件,子组件通过$emit触发事件。适用于子组件向父组件传递数据或触发某些操作。
  3. $refs:父组件通过ref属性获取子组件的实例,从而调用子组件的方法或获取子组件的数据。
  4. $parent / $children:通过$parent属性获取父组件实例,通过$children属性获取子组件实例。可以直接访问父组件或子组件的数据和方法。
  5. Event Bus:通过创建一个全局的Vue实例,并使用$on、$emit等方法进行事件的监听和触发。不限制组件之间的层级关系,适用于任意组件之间的通信。
  6. Vuex:Vue的状态管理库,用于管理多个组件共享的状态数据。通过定义store、state、mutations等概念,实现组件之间的数据共享与通信。

适用场景:

  • Props / $emit:父子组件之间的数据传递。
  • 自定义事件:兄弟组件之间的数据传递或触发操作。
  • $refs:父组件获取子组件的数据或调用子组件的方法。
  • $parent / $children:父子组件之间的数据传递或方法调用。
  • Event Bus:任意组件之间的通信。
  • Vuex:大型应用中,多个组件需要共享数据的情况。

在Vue中,组件通信可以通过props、$emit、$on和$emit等方式来实现。

  1. 父组件向子组件传递数据:使用props 父组件可以通过props属性将数据传递给子组件。子组件可以在props中定义接收的属性,然后通过子组件的模板中使用这些属性。
// 父组件
<template>
  <child-component :message="parentMsg"></child-component>
</template>
<script>
export default {
  data() {
    return {
      parentMsg: 'Hello from parent'
    }
  }
}
</script>
// 子组件
<template>
  <div>{{ message }}</div>
</template>
<script>
export default {
  props: ['message']
}
</script>
  1. 子组件向父组件传递数据:使用$emit 子组件可以使用$emit方法触发一个自定义事件,并传递数据给父组件。父组件可以在模板中监听这个自定义事件,并处理传递的数据。
// 子组件
<template>
  <button @click="sendMessage">Send Message</button>
</template>
<script>
export default {
  methods: {
    sendMessage() {
      this.$emit('message', 'Hello from child')
    }
  }
}
</script>
// 父组件
<template>
  <child-component @message="handleMessage"></child-component>
</template>
<script>
export default {
  methods: {
    handleMessage(msg) {
      console.log(msg) // 输出:Hello from child
    }
  }
}
</script>
  1. 兄弟组件之间传递数据:使用事件总线 可以创建一个Vue实例作为事件总线,兄弟组件通过事件总线来通信。
// EventBus.js
import Vue from 'vue'
export default new Vue()
// 组件A
<template>
  <div>
    <button @click="sendMessage">Send Message</button>
  </div>
</template>
<script>
import EventBus from './EventBus'
export default {
  methods: {
    sendMessage() {
      EventBus.$emit('message', 'Hello from component A')
    }
  }
}
</script>
// 组件B
<template>
  <div>
    <div>{{ message }}</div>
  </div>
</template>
<script>
import EventBus from './EventBus'
export default {
  data() {
    return {
      message: ''
    }
  },
  created() {
    EventBus.$on('message', (msg) => {
      this.message = msg
    })
  }
}
</script>

这里仅展示了Vue中几种常用的组件通信方式和应用场景的代码示例,实际应用中还可以根据具体需求选择合适的通信方式。

相关文章
|
15天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
82 1
|
11天前
|
敏捷开发 人工智能 JavaScript
Figma-Low-Code:快速将Figma设计转换为Vue.js应用,支持低代码渲染、数据绑定
Figma-Low-Code 是一个开源项目,能够直接将 Figma 设计转换为 Vue.js 应用程序,减少设计师与开发者之间的交接时间,支持低代码渲染和数据绑定。
40 3
Figma-Low-Code:快速将Figma设计转换为Vue.js应用,支持低代码渲染、数据绑定
|
6天前
|
JavaScript 前端开发
【Vue.js】监听器功能(EventListener)的实际应用【合集】
而此次问题的核心就在于,Vue实例化的时机过早,在其所依赖的DOM结构尚未完整构建完成时就已启动挂载流程,从而导致无法找到对应的DOM元素,最终致使计算器功能出现异常,输出框错误地显示“{{current}}”,并且按钮的交互功能也完全丧失响应。为了让代码结构更为清晰,便于后续的维护与管理工作,我打算把HTML文件中标签内的JavaScript代码迁移到外部的JS文件里,随后在HTML文件中对其进行引用。
26 8
|
26天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript 前端开发 API
Vue.js 3:深入探索组合式API的实践与应用
Vue.js 3:深入探索组合式API的实践与应用
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
54 1
vue学习第一章
|
2月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
49 1
|
2月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
43 1
vue学习第四章
|
2月前
|
JavaScript 前端开发 算法
vue学习第7章(循环)
欢迎来到瑞雨溪的博客,一名热爱JavaScript和Vue的大一学生。本文介绍了Vue中的v-for指令,包括遍历数组和对象、使用key以及数组的响应式方法等内容,并附有综合练习实例。关注我,将持续更新更多优质文章!🎉🎉🎉
35 1
vue学习第7章(循环)