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中怎么实现组件通信的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。