Vue2.0基于vue-cli+webpack同级组件之间的通信教程(推荐)


Posted in Javascript onSeptember 14, 2017

我们接着上文继续,本文我们讲解兄弟组件的通信,项目结构还是跟上文一样.

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

EventHandler.js代码:

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

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

<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

<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中调用两个同级组件

<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同级组件之间的通信教程(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
原生js实现shift/ctrl/alt按键的获取
Apr 08 Javascript
JQuery+Ajax无刷新分页的实例代码
Feb 08 Javascript
使用Node.js配合Nginx实现高负载网络
Jun 28 Javascript
解决JavaScript数字精度丢失问题的方法
Dec 03 Javascript
javascript事件委托的用法及其好处简析
Apr 04 Javascript
JavaScript模板引擎Template.js使用详解
Dec 15 Javascript
angularjs点击图片放大实现上传图片预览
Feb 24 Javascript
Django+Vue跨域环境配置详解
Jul 06 Javascript
angularJs中$scope数据序列化的实例
Sep 30 Javascript
VUE v-model表单数据双向绑定完整示例
Jan 21 Javascript
微信小程序项目总结之记账小程序功能的实现(包括后端)
Aug 20 Javascript
解决vue-photo-preview 异步图片放大失效的问题
Jul 29 Javascript
Vue2.0基于vue-cli+webpack父子组件通信(实例讲解)
Sep 14 #Javascript
对于js垃圾回收机制的理解
Sep 14 #Javascript
使用SVG基本操作API的实例讲解
Sep 14 #Javascript
JSON 数据格式详解
Sep 13 #Javascript
JS库 Highlightjs 添加代码行号的实现代码
Sep 13 #Javascript
详解动画插件wow.js的使用方法
Sep 13 #Javascript
JS库之Highlight.js的用法详解
Sep 13 #Javascript
You might like
用PHP连接Oracle for NT 远程数据库
2006/10/09 PHP
我的论坛源代码(七)
2006/10/09 PHP
目录,文件操作详谈―PHP
2006/11/25 PHP
相对路径转化成绝对路径
2007/04/10 PHP
使用PHP遍历文件目录与清除目录中文件的实现详解
2013/06/24 PHP
解析获取优酷视频真实下载地址的PHP源代码
2013/06/26 PHP
php实现搜索类封装示例
2016/03/31 PHP
JAVASCRIPT 对象的创建与使用
2021/03/09 Javascript
JS实现下拉框的动态添加(附效果)
2013/04/03 Javascript
jQuery将多条数据插入模态框的示例代码
2014/09/25 Javascript
浅析javascript中的DOM
2015/03/01 Javascript
jquery使用slideDown实现模块缓慢拉出效果的方法
2015/03/27 Javascript
JavaScript Math.round() 方法
2015/12/18 Javascript
Bootstrap自定义文件上传下载样式
2016/05/26 Javascript
JS简单去除数组中重复项的方法
2016/09/13 Javascript
15个非常实用的JavaScript代码片段
2016/12/18 Javascript
详解微信开发中snsapi_base和snsapi_userinfo及静默授权的实现
2017/03/11 Javascript
JS实现静态页面搜索并高亮显示功能完整示例
2017/09/19 Javascript
jQuery实现下拉菜单动态添加数据点击滑出收起其他功能
2018/06/14 jQuery
详解如何webpack使用DllPlugin
2018/09/30 Javascript
了解前端理论:rscss和rsjs
2019/05/23 Javascript
layui插件表单验证提交触发提交的例子
2019/09/09 Javascript
VScode格式化ESlint方法(最全最好用方法)
2019/09/10 Javascript
一波神奇的Python语句、函数与方法的使用技巧总结
2015/12/08 Python
Python中字符串格式化str.format的详细介绍
2017/02/17 Python
Python实现的单向循环链表功能示例
2017/11/10 Python
python手写均值滤波
2020/02/19 Python
Python多线程的退出控制实现
2020/08/10 Python
Linux的主要特性
2016/09/03 面试题
教师岗位职责
2013/11/17 职场文书
售后专员岗位职责
2013/12/08 职场文书
2015年光棍节活动总结
2015/03/24 职场文书
限期整改通知书
2015/04/22 职场文书
生活委员竞选稿
2015/11/21 职场文书
nginx配置proxy_pass中url末尾带/与不带/的区别详解
2021/03/31 Servers
一篇文章带你掌握SQLite3基本用法
2022/06/14 数据库