vue全家桶进阶之路17:组件与组件间的通信
在 Vue2 中,组件与组件之间的通信可以通过以下几种方式来实现:
- Props 和 Events
这是 Vue2 中最基础和常用的父子组件通信方式。父组件通过属性传递数据给子组件,子组件通过事件触发向父组件传递数据。
父组件传递数据到子组件:
<template>
<div>
<child-component :message="message"></child-component>
</div>
</template> <script>
import ChildComponent from './ChildComponent.vue'; export default {
components: {
ChildComponent
},
data() {
return {
message: 'Hello, World!'
}
}
}
</script>
子组件接收父组件传递的数据
<template>
<div>{{ message }}</div>
</template> <script>
export default {
props: {
message: String
}
}
</script>
子组件向父组件传递数据:
<template>
<div>
<button @click="$emit('update-message', 'Hello, Vue!')">Update Message</button>
</div>
</template>
父组件监听子组件触发的事件:
<template>
<div>
<child-component @update-message="onMessageUpdated"></child-component>
</div>
</template> <script>
import ChildComponent from './ChildComponent.vue'; export default {
components: {
ChildComponent
},
methods: {
onMessageUpdated(message) {
console.log(message);
}
}
}
</script>
- $parent 和 $children
在 Vue2 中,每个组件实例都有 $parent 和 $children 属性,可以用来访问组件的父组件和子组件实例。
父组件可以通过 $children 访问子组件:
<template>
<div>
<child-component></child-component>
</div>
</template> <script>
import ChildComponent from './ChildComponent.vue'; export default {
components: {
ChildComponent
},
mounted() {
console.log(this.$children[0].message);
}
}
</script>
子组件可以通过 $parent 访问父组件:
<template>
<div>{{ $parent.message }}</div>
</template> <script>
export default {
mounted() {
console.log(this.$parent.message);
}
}
</script>
- $refs
在 Vue2 中,可以使用 $refs 来访问组件的引用。可以通过 $refs 访问组件实例的方法和属性,也可以通过 $refs 传递数据。
<template>
<div>
<child-component ref="childComponent"></child-component>
<button @click="updateMessage">Update Message</button>
</div>
</template> <script>
import ChildComponent from './ChildComponent.vue'; export default {
components: {
ChildComponent
},
methods: {
updateMessage() {
this.$refs.childComponent.updateMessage('Hello, Vue!');
}
}
}
</script>
<template>
<div>{{ message }}</div>
</template> <script>
export default {
data() {
return {
message:'Hello, World!' }
},
methods: {
updateMessage(message) { this.message = message;}
}
}
</script>
4. Event Bus 在 Vue2 中,可以使用事件总线来实现任意组件之间的通信。事件总线本质上是一个空的 Vue 实例,用来作为中央事件总线,任意组件都可以监听事件和触发事件。 创建事件总线:
```javascript
// EventBus.js
import Vue from 'vue';
export const EventBus = new Vue(); <template>
<div>
<button @click="updateMessage">Update Message</button>
</div>
</template> <script>
import { EventBus } from './EventBus.js'; export default {
methods: {
updateMessage() {
EventBus.$emit('update-message', 'Hello, Vue!');
}
}
}
</script>
组件之间传递数据:
<template>
<div>
<button @click="updateMessage">Update Message</button>
</div>
</template> <script>
import { EventBus } from './EventBus.js'; export default {
methods: {
updateMessage() {
EventBus.$emit('update-message', 'Hello, Vue!');
}
}
}
</script>
组件接收数据:
<template>
<div>{{ message }}</div>
</template> <script>
import { EventBus } from './EventBus.js'; export default {
data() {
return {
message: 'Hello, World!'
}
},
mounted() {
EventBus.$on('update-message', message => {
this.message = message;
});
}
}
</script>
- Vuex
如果组件之间的通信比较复杂,或者需要在多个组件之间共享数据,可以使用 Vuex。Vuex 是一个专门为 Vue.js 应用程序开发的状态管理模式,它集中管理组件之间共享的数据。
创建 store:
// store.js
import Vue from 'vue';
import Vuex from 'vuex';
Vue.use(Vuex); export const store = new Vuex.Store({
state: {
message: 'Hello, World!'
},
mutations: {
updateMessage(state, message) {
state.message = message;
}
},
actions: {
updateMessage(context, message) {
context.commit('updateMessage', message);
}
}
});
在组件中访问 store 中的数据:
<template>
<div>{{ message }}</div>
</template> <script>
import { mapState } from 'vuex'; export default {
computed: {
...mapState(['message'])
}
}
</script>
在组件中触发 action:
<template>
<div>
<button @click="updateMessage">Update Message</button>
</div>
</template> <script>
import { mapActions } from 'vuex'; export default {
methods: {
...mapActions(['updateMessage'])
}
}
</script>
更多关于 Vuex 的内容可以参考官方文档:https://vuex.vuejs.org/zh/
vue全家桶进阶之路17:组件与组件间的通信的更多相关文章
- Vue全家桶之组件化开发
Vue全家桶之组件化开发 一.组件 组件 (Component) 是 Vue.js 最强大的功能之一 组件可以扩展 HTML 元素,封装可重用的代码 二. 组件注册 2.1 全局注册 Vue. ...
- Vue 全家桶 + Electron 开发的一个跨三端的应用
代码地址如下:http://www.demodashi.com/demo/11738.html GitHub Repo:vue-objccn Follow: halfrost · GitHub 利用 ...
- 升级vue全家桶过程记录
背景 如果你使用了element-ui的el-tabs组件,并且想要单独升级element-ui至2.10.0,你会发现,使用了el-tabs组件的页面只要打开就卡死.原因是element-ui~2. ...
- vue证明题一,vue全家桶的构成
简单说下vue的构成,当然是简单为主,网上这东西满天飞,简单说几句就ok 1.vue是什么 vue读作view,是一种js框架.只关注于视图层,操作内容包括js,html,css 2.vue全家桶是什 ...
- Vue全家桶
简介 “简单却不失优雅,小巧而不乏大匠”. Vue.js 是一个JavaScriptMVVM库,是一套构建用户界面的渐进式框架.它是以数据驱动和组件化的思想构建的,采用自底向上增量开发的设计. 为什么 ...
- 从零开始系列之vue全家桶(3)安装使用vuex
什么是vuex? vuex:Vue提供的状态管理工具,用于同一管理我们项目中各种数据的交互和重用,存储我们需要用到数据对象. 即data中属性同时有一个或几个组件同时使用,就是data中共用的属性. ...
- 使用vue全家桶制作博客网站
前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用vue全家桶制作的博客网站 概述 该项目是基于vue全家桶(vue.vue-router.vuex.v ...
- 转载: 使用vue全家桶制作博客网站 HTML5 移动网站制作的好教程
使用vue全家桶制作博客网站 前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用vue全家桶制作的博客网站 概述 该项目是基于vue全家桶(vue. ...
- Vue全家桶介绍
一直不清楚全家桶是什么玩意,上网搜了一下,才知道就是平时项目中使用的几个依赖包,下面分享一下 Vue 全家桶介绍 Vue有著名的全家桶系列,包含了vue-router(http://router.vu ...
- 一个简单的假vue全家桶(vue+vue-router+require)
首先说明我觉得这是一个比较好理解的vue全家桶(虽然是假的),模块化也是用require来做的,而且如果后期有必要压缩我也会用gulp来做 1.依赖个个本地模块,require只是用来载入page,这 ...
随机推荐
- 基于leaflet地图可视化(一)
最近,在学习地图可视化是基于公司的项目.但公司在项目上居然用图片来代替.无语~~~项目效果图(第一版)如下: 突发奇想,2016年自己就接触过地图可视化.但那是没有深入研究.只会用R语言来实现点基础. ...
- ImageUtils excel 中 emf 转图片(解决图片上部分显示不全问题)图片转文字
excel 中ActiveX 工具 中的textbox ,以及公式 解析后为emf 图片, emf 转图片(解决图片上部分显示不全问题) 图片转文字 /*********************** ...
- k8s 关于pull image failed 问题
问题描述: Failed to pull image "nginx": rpc error: code = Unknown desc = failed to pul 解决办法: 1 ...
- conda使用杂记
总纲 https://docs.anaconda.com/anaconda/navigator/ 其中有链接 miniconda https://docs.anaconda.com/anaconda/ ...
- ansible用authorized_key模块批量推送密钥到受控主机实现免密登录
一,ansible的authorized_key模块的用途 用来配置密钥实现免密登录: ansible所在的主控机生成密钥后,如何把公钥上传到受控端? 当然可以用ssh-copy-id命令逐台手动处理 ...
- MyBatis 延迟加载代码详解
在我们的实际开发中,会面临各种各样的查询操作.如果单表查询能满足业务需求.尽量用单表查询,因为单表查询的效率比多表关联查询快. 那么当业务需求需要用到的数据来源于多张表的时候,单表查询无法解决,Myb ...
- 网络----OSI七层
OSI 订制的是一个用于计算机或通信系统间互联的标准体质(一般称为OSI参考模型或七层模型) OSI 模型把网络通信的工作分为7层分别是: 常用内容:物理层 数据链层 网络层 注解 OSI 7层 1. ...
- Python 霸榜的一周,又有什么新 AI 力作呢?「GitHub 热点速览」
GPT 带火了一波语言模型,LLaMA 和 Alpaca 也在持续发力.依旧是各类 GPT 后缀霸榜 GitHub trending 的一周,为此特推部分专门收录了两个比较不错的 GPT 应用.而作为 ...
- elasticsearch 官方优化建议
1.一般建议 a.不要返回过大的结果集.这个建议对一般数据库都是适用的,如果要获取大量结果,可以使用search_after api,或者scroll (新版本中已经不推荐). b.避免大的文 ...
- postgresSQL Extended Query执行过程和sharding-proxy的处理
pg Extended Query PostgreSQL: Documentation: 15: 55.2. Message Flow 多个阶段,可复用 Parse → DESCRIBE statem ...