Vuejs 用$emit与$on来进行兄弟组件之间的数据传输通信


Posted in Javascript onFebruary 23, 2017

最近在学习vue组件鸡组件之前通信问题,正好看到,以此来留作笔记。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <title>Vue2-单一事件管理组件通信</title>
  <script src="vue.js"></script>
  <script type="text/javascript">

  //准备一个空的实例对象
  var Event = new Vue();

  //组件A
  var A = {
    template: `
      <div>
        <span>我是A组件的数据->{{a}}</span>
        <input type="button" value="把A数据传给C" @click = "send">
      </div>
    `,
    methods: {
      send () {
        Event.$emit("a-msg", this.a);
      }
    },
    data () {
      return {
        a: "我是a组件中数据"
      }
    }
  };
  //组件B
  var B = {
    template: `
      <div>
        <span>我是B组件的数据->{{a}}</span>
        <input type="button" value="把B数据传给C" @click = "send">
      </div>
    `,
    methods: {
      send () {
        Event.$emit("b-msg", this.a);
      }
    },
    data () {
      return {
        a: "我是b组件中数据"
      }
    }
  };
  //组件C
  var C = {
    template: `
      <div>
        <h3>我是C组件</h3>
        <span>接收过来A的数据为: {{a}}</span>
        <br>
        <span>接收过来B的数据为: {{b}}</span>
      </div>
    `,
    mounted () {
      //接收A组件的数据
      Event.$on("a-msg", function (a) {
        this.a = a;
      }.bind(this));

      //接收B组件的数据
      Event.$on("b-msg", function (a) {
        this.b = a;
      }.bind(this));
    },
    data () {
      return {
        a: "",
        b: ""
      }
    }
  };
  window.onload = function () {
    new Vue({
      el: "#box",
      components: {
        "dom-a": A,
        "dom-b": B,
        "dom-c": C
      }
    });
  };


  </script>
</head>
<body>
  <div id="box">
    <dom-a></dom-a>   
    <dom-b></dom-b>   
    <dom-c></dom-c>   
  </div>

</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 密码强度验证规则、打分、验证(给出前端代码,后端代码可根据强度规则翻译)
May 18 Javascript
Jquery插件写法笔记整理
Sep 06 Javascript
jquery实现简单合拢与展开网页面板的方法
Sep 01 Javascript
js倒计时抢购实例
Dec 20 Javascript
AngularJS 使用$sce控制代码安全检查
Jan 05 Javascript
深入理解AngularJS中的ng-bind-html指令和$sce服务
Sep 08 Javascript
jQuery居中元素scrollleft计算方法示例
Jan 16 Javascript
JavaScript通过filereader接口读取文件
May 10 Javascript
微信小程序 支付功能(前端)的实现
May 24 Javascript
Vue 通过自定义指令回顾v-内置指令(小结)
Sep 03 Javascript
Vue CLI3基础学习之pages构建多页应用
Jun 02 Javascript
Webpack3+React16代码分割的实现
Mar 03 Javascript
微信小程序 开发之顶部导航栏实例代码
Feb 23 #Javascript
jQuery中绑定事件bind() on() live() one()的异同
Feb 23 #Javascript
js实现简单的选项卡效果
Feb 23 #Javascript
Vue-resource实现ajax请求和跨域请求示例
Feb 23 #Javascript
jQuery事件详解
Feb 23 #Javascript
Vue2学习笔记之请求数据交互vue-resource
Feb 23 #Javascript
JavaScript基本类型值-Undefined、Null、Boolean
Feb 23 #Javascript
You might like
深入PHP autoload机制的详解
2013/06/09 PHP
教你如何解密 “ PHP 神盾解密工具 ”
2014/06/20 PHP
详解PHP文件的自动加载(autoloading)
2018/02/04 PHP
基于Unit PNG Fix.js有时候在ie6下不正常的解决办法
2013/06/26 Javascript
再谈Jquery Ajax方法传递到action(补充)
2014/05/12 Javascript
Javascript学习笔记之 对象篇(三) : hasOwnProperty
2014/06/24 Javascript
鼠标经过出现气泡框的简单实例
2017/03/17 Javascript
基于vue的fullpage.js单页滚动插件
2017/03/20 Javascript
详解vue的数据binding绑定原理
2017/04/12 Javascript
Webpack如何引入bootstrap的方法
2017/06/17 Javascript
AngularJS service之select下拉菜单效果
2017/07/28 Javascript
JS设计模式之单例模式(一)
2017/09/29 Javascript
javascript中new Array()和var arr=[]用法区别
2017/12/01 Javascript
详解vue-router 命名路由和命名视图
2018/06/01 Javascript
详解vue中的父子传值双向绑定及数据更新问题
2019/06/13 Javascript
js变量值传到php过程详解 将php解析成数据
2019/06/26 Javascript
JS数组方法reduce的用法实例分析
2020/03/03 Javascript
如何利用 JS 脚本实现网页全自动秒杀抢购功能
2020/10/12 Javascript
python获取酷狗音乐top500的下载地址 MP3格式
2018/04/17 Python
在PyCharm中遇到pip安装 失败问题及解决方案(pip失效时的解决方案)
2020/03/10 Python
TensorFlow keras卷积神经网络 添加L2正则化方式
2020/05/22 Python
Python文件名匹配与文件复制的实现
2020/12/11 Python
服装销售人员求职自我评价
2013/09/26 职场文书
酒店保洁主管岗位职责
2013/11/28 职场文书
校园奶茶店创业计划书
2014/01/23 职场文书
人力资源经理的岗位职责范本
2014/02/28 职场文书
财务总监管理职责范文
2014/03/09 职场文书
社区交通安全实施方案
2014/03/22 职场文书
弘扬民族精神演讲稿
2014/05/07 职场文书
四风问题个人剖析材料
2014/10/07 职场文书
教师工作决心书
2015/02/04 职场文书
神龙架导游词
2015/02/11 职场文书
董事会决议范本
2015/07/01 职场文书
2015年小学教师培训工作总结
2015/07/21 职场文书
小学2016年“我们的节日·重阳节”活动总结
2016/04/01 职场文书
springBoot基于webSocket实现扫码登录
2021/06/22 Java/Android