源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

在vue-cli中组件通信的方法

  • 时间:2022-03-24 00:52 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:在vue-cli中组件通信的方法
本文介绍了在vue-cli中组件通信的方法,分享给大家。具体如下: vue组件之间的通信包括三种: 1.父组件向子组件通信 2.子组件向父组件通信 3.同级组件之间的通信 [b]一.父传子组件通信[/b] [img]http://files.jb51.net/file_images/article/201712/2017121694435249.png?2017111694454[/img] 拿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>
[b]二.子与父组件通信[/b] 子组件:
<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;
  }
}

[b]二.非父子组件通信[/b]
//把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'
  })
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部