在vue-cli中组件通信的方法
内容摘要
这篇文章主要为大家详细介绍了在vue-cli中组件通信的方法,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
本文介绍了在vue-cli中组件通信
对此感兴趣的朋友,看看idc笔记做的技术笔记!
本文介绍了在vue-cli中组件通信
文章正文
这篇文章主要为大家详细介绍了在vue-cli中组件通信的方法,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
本文介绍了在vue-cli中组件通信的方法,分享给大家。具体如下:
vue组件之间的通信包括三种:
1.父组件向子组件通信2.子组件向父组件通信3.同级组件之间的通信
一.父传子组件通信
【512pic.com温馨提示:图片暂缺】
拿app.vue当父组件,content.vue当子组件
1.父组件中导入子组件(子组件导出)
代码如下:
import contents from './components/content';
2.在父组件中注册子组件
代码如下:
data() {
return {
test:'0'
};
},
components:{
'v-header':headers,
'v-content':contents
}
3.子组件通过props来接收数据
代码如下:
<v-content :childs='test'></v-content>
二.子与父组件通信
子组件:
代码如下:
<template>
<div @click="down()"></div>
</template>
methods: {
down() {
this.$emit('down','null'); //主动触发down方法,'null'为向父组件传递的数据
}
}
父组件:
代码如下:
<div>
<child @down="changes" :test="test"></child> //监听子组件触发的down事件,然后调用changes方法
</div>
methods: {
changes(msg) {
this.test= test;
}
}
二.非父子组件通信
代码如下:
//把a当作一个中转站
var a = new Vue();
组件1触发:
代码如下:
<div @click="eve"></div>
methods:{
eve(){
a.$emit("change",'null')
}
}
组件2接收:
代码如下:
<div></div>
created(){
a.$on('change',()=>{
this.msg = 'null'
})
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持php教程。
注:关于在vue-cli中组件通信的方法的内容就先介绍到这里,更多相关文章的可以留意
代码注释