zoukankan      html  css  js  c++  java
  • Vue2.0基于vue-cli+webpack同级组件之间的通信教程(推荐)

    在src/assets目录下建立文件EventHandler.js,该文件的作用在于给同级组件之间传递事件

    EventHandler.js代码:

    1
    2
    import Vue from 'Vue';
    export default new Vue();

    1,在Components目录下新建一个组件Brother1.vue

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    <template>
     <div>
      <h3>Z国: ghostwu</h3>
      <input v-on:click="send" type="button" value="发送">
      <p>{{msg}}</p>
     </div>
    </template>
    <script>
     import EventHandler from '../assets/EventHandler.js';
     export default {
      data(){
       return {
        msg : ''
       }
      },
      methods : {
       send(){
        EventHandler.$emit( 'myDefineEv', "ghostwu向岛国发射了一颗原子弹" );
       }
      },
      mounted (){
       let _this = this;
       EventHandler.$on( "RDefineEv", function( data ){
        _this.msg = data;
       } );
      }
     }
    </script>

    。通过EventHandler.$emit发送一个自定义事件myDefineEv

    。通过mouted【相当于jquery的ready, 原生js的onload】,这个是vue生命周期的钩子函数, 用于在页面加载完成之后执行代码,在这里就是接收RDefineEv事件( Brother2.vue定义的 )

    2,在Components目录下新建一个组件Brother2.vue

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    <template>
     <div>
      <h3>R国:八嘎</h3>
      {{msg}}
      <input v-on:click="defend" type="button" value="防御">
     </div>
    </template>
    <script>
     import EventHandler from '../assets/EventHandler.js';
     export default {
      data(){
       return {
        msg : ''
       }
      },
      methods : {
       defend(){
         EventHandler.$emit( 'RDefineEv', "岛国采用了高科技反原子弹系统" );
       }
      },
      mounted(){
       let _this = this;
       EventHandler.$on( "myDefineEv", function( data ){
        _this.msg = data;
       } );
      }
     }
    </script>

    。点击按钮发送RDefineEv事件

    。文档ready的时候,接收myDefineEv(Brother1.vue)出发的自定义事件

    三、在App.vue中调用两个同级组件

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    <template>
     <div id="app">
     <Brother1></Brother1>
     <Brother2></Brother2>
     </div>
    </template>
     
    <script>
     import Brother1 from './components/Brother1.vue';
     import Brother2 from './components/Brother2.vue';
     
     export default {
     components : {
      Brother1,
      Brother2
     }
     }
    </script>

    小结:

    创建一个事件传递中心,例如EventHandler.js,用它作为传递消息的中介

    在需要传值的组件中用EventHandler.$emit触发一个自定义事件,并传递参数

    在需要接收数据的组件中用EventHandler.$on监听自定义事件,并在回调函数中处理传递过来的参数

    以上这篇Vue2.0基于vue-cli+webpack同级组件之间的通信教程(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

  • 相关阅读:
    pyqt中使用matplotlib绘制动态曲线 – pythonic
    pyqt开发教程-搭建环境和开发示例
    QPointer很大程度上避免了野指针(使用if语句判断即可,类似于dynamic_cast),而且使用非常方便 good
    qt5集成libcurl实现tftp和ftp的方法一:搭建环境(五篇文章)
    终于懂了:两个UI组件同时在操作是不可能实现的
    c/s 自动升级(WebService)
    web form中自定义HttpHandler仿mvc
    eclipse plugin 导出插件包
    TaskTracker执行map或reduce任务的过程2
    Jquery多级菜单插件Slimmenu使用说明
  • 原文地址:https://www.cnblogs.com/vsmart/p/9334559.html
Copyright © 2011-2022 走看看