vue-cli中怎么实现组件通信
短信预约 -IT技能 免费直播动态提醒
vue-cli中怎么实现组件通信,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
一.父传子组件通信
拿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'
})
}
看完上述内容,你们掌握vue-cli中怎么实现组件通信的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341