vue中的$emit 与$on父子组件与兄弟组件的之间通信方式


Posted in Javascript onMay 13, 2018

本文主要对vue 用$emit 与 $on 来进行组件之间的数据传输.

主要的传输方式有三种:

1.父组件到子组件通信

2.子组件到父组件的通信

3.兄弟组件之间的通信

一、父组件传值给子组件

父组件给子组件传子,使用props

//父组件:parent.vue
<template>
  <div>
    <child :vals = "msg"></child>
  </div>
</template>
<script>
import child from "./child";
export default {
  data(){
    return {
      msg:"我是父组件的数据,将传给子组件"
    }
  },
  components:{
    child
  }
}
</script>

//子组件:child.vue
<template>
  <div>
    {{vals}}
  </div>
</template>
<script>
export default {
   props:{ //父组件传值 可以是一个数组,对象
    vals:{
      type:String,//类型为字符窜
     default:"123" //可以设置默认值
    }
  },
}
</script>

2.子组件到父组件的通信

使用 $emit(eventname,option) 触发事件,

参数一:自定义事件名称,写法,小写或者用-连接,如event,event-name 不能写驼峰写法(eventName)

子组件给父组件传值,可以在子组件中使用$emit触发事件的值传出去,父组件通过事件监听,获取数据

但是,这里有一个问题,

1、究竟是由子组件内部主动传数据给父组件,由父组件监听接收(由子组件中操作决定什么时候传值)

2、还是通过父组件决定子组件什么时候传值给父组件,然后再监听接收 (由父组件中操作决定什么时候传值)

两种情况都有

2.1 : $meit事件触发,通过子组件内部的事件触发自定义事件$emit

2.2 : $meit事件触发, 可以通过父组件操作子组件 (ref)的事件来触发 自定义事件$emit

第一种情况:

//父组件:parent.vue
<template>
  <div>
    <child v-on:childevent='wathChildEvent'></child>
    <div>子组件的数据为:{{msg}}</div>
  </div>
</template>
<script>
import child from "./child";
export default {
  data(){
    return{
      msg:""
    }
  },
  components:{
    child
  },
  methods:{
    wathChildEvent:function(vals){//直接监听 又子组件触发的事件,参数为子组件的传来的数据
      console.log(vals);//结果:这是子组件的数据,将有子组件操作触发传给父组件
      this.msg = vlas;
    } 
  }
}
</script>
//子组件:child.vue
<template>
  <div>
    <input type="button" value="子组件触发" @click="target">
  </div>
</template>
<script>
export default {
  data(){
      return {
      texts:'这是子组件的数据,将有子组件操作触发传给父组件'
      }
  },
  methods:{
    target:function(){ //有子组件的事件触发 自定义事件childevent
      this.$emit('childevent',this.texts);//触发一个在子组件中声明的事件 childEvnet
    }
  },
}
</script>

第二种情况:

//父组件:parent.vue
<template>
  <div>
    <child v-on:childevent='wathChildEvent' ref="childcomp"></child>
    <input type="button" @click="parentEnvet" value="父组件触发" />
    <div>子组件的数据为:{{msg}}</div>
  </div>
</template>
<script>
import child from "./child";
export default {
  data(){
    return{
      msg:""
    }
  },
  components:{
    child
  },
  methods:{
    wathChildEvent:function(vals){//直接监听 又子组件触发的事件,参数为子组件的传来的数据
      console.log(vals);//这是子组件的数据,将有子组件操作触发传给父组件
      this.msg = vlas;
    },
    parentEnvet:function(){
      this.$refs['childcomp'].target(); //通过refs属性获取子组件实例,又父组件操作子组件的方法触发事件$meit
    }
  }
}
</script>
//子组件:child.vue
<template>
  <div>
   <!-- dothing..... -->
  </div>
</template>
<script>
export default {
  data(){
      return {
      texts:'这是子组件的数据,将有子组件操作触发传给父组件'
      }
  },
  methods:{
    target:function(){ //又子组件的事件触发 自定义事件childevent
      this.$emit('childevent',this.texts);//触发一个在子组件中声明的事件 childEvnet
    }
  },
}
</script>

将两者情况对比,区别就在于$emit 自定义事件的触发是有父组件还是子组件去触发

第一种,是在子组件中定义一个click点击事件来触发自定义事件$emit,然后在父组件监听

第二种,是在父组件中第一一个click点击事件,在组件中通过refs获取实例方法来直接触发事件,然后在父组件中监听

3.兄弟组件之间的通信

 (1)、兄弟之间传递数据通过事件

 (2)、创建一个新Vue的实例,让各个兄弟共用同一个事件机制。(关键点)

 (3)、传递数据方,通过事件触发$emit(方法名,传递的数据)。

 (4)、接收数据方,在mounted()钩子函数(挂载实例)中 触发事件$on(方法名,callback(接收数据的数据)),此时callback函数中的this已经发生了改变,可以使用箭头函数。

//建立一个空的Vue实例,将通信事件挂载在该实例上
//emptyVue.js
import Vue from 'vue'
export default new Vue()
//兄弟组件a:childa.vue
<template>
  <div>
    <span>A组件->{{msg}}</span>
    <input type="button" value="把a组件数据传给b" @click ="send">
  </div>
</template>
<script>
import vmson from "./emptyVue"
export default {
  data(){
    return {
      msg:"我是a组件的数据"
    }
  },
  methods:{
    send:function(){
      vmson.$emit("aevent",this.msg)
    }
  }
}
</script>
//兄弟组件b:childb.vue
<template>
   <div>
    <span>b组件,a传的的数据为->{{msg}}</span>
  </div>
</template>
<script>
import vmson from "./emptyVue"
export default {
 data(){
    return {
      msg:""
    }
  },
  mounted(){
    vmson.$on("aevent",(val)=>{//监听事件aevent,回调函数要使用箭头函数;
      console.log(val);//打印结果:我是a组件的数据
      this.msg = val;
    })
  }
}
</script>
//父组件:parent.vue
<template>
  <div>
    <childa><childa>
    <childb></childb>
  </div>
</template>
<script>
import childa from "./childa";
import childb from "./childb";
export default {
  data(){
    return{
      msg:""
    }
  },
  components:{
    childa,
    childb
  },
}
</script>

到此,vue中的组件通信传值基本可以搞定了,但是对于大型复杂的项目,建议采用vuex 状态管理更适合....

推荐参考学习:https://vuex.vuejs.org/zh-cn/

    https://cn.vuejs.org/v2/api/#vm-emit

   https://cn.vuejs.org/v2/api/#vm-on

总结

以上所述是小编给大家介绍的vue中的$emit 与$on父子组件与兄弟组件的之间通信方式,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
js 刷新页面的代码小结 推荐
Apr 02 Javascript
基于jQuery选择器的整理集合
Apr 26 Javascript
点击弹出层外区域关闭弹出层jquery特效示例
Aug 25 Javascript
node.js开发中使用Node Supervisor实现监测文件修改并自动重启应用
Nov 04 Javascript
JavaScript运动减速效果实例分析
Aug 04 Javascript
基于JavaScript如何实现ajax调用后台定义的方法
Dec 29 Javascript
浅述节点的创建及常见功能的实现
Dec 15 Javascript
easyui datebox 时间限制,datebox开始时间限制结束时间,datebox截止日期比起始日期大的实现代码
Jan 12 Javascript
javascript流程控制语句集合
Sep 18 Javascript
Vue v2.4中新增的$attrs及$listeners属性使用教程
Jan 08 Javascript
vue内置组件keep-alive事件动态缓存实例
Oct 30 Javascript
vue.js 使用原生js实现轮播图
Apr 26 Vue.js
node 命令方式启动修改端口的方法
May 12 #Javascript
安装Node.js并启动本地服务的操作教程
May 12 #Javascript
Node.js中,在cmd界面,进入退出Node.js运行环境的方法
May 12 #Javascript
Vue拖拽组件开发实例详解
May 11 #Javascript
node前端模板引擎Jade之标签的基本写法
May 11 #Javascript
JS实现的简单下拉框联动功能示例
May 11 #Javascript
JS实现table表格内针对某列内容进行即时搜索筛选功能
May 11 #Javascript
You might like
真正面向对象编程:PHP5.01发布
2006/10/09 PHP
PHP生成静态页面详解
2006/11/19 PHP
PHP使用Session遇到的一个Permission denied Notice解决办法
2014/07/30 PHP
PHP实现数据分页显示的简单实例
2016/05/26 PHP
PHP和MYSQL实现分页导航思路详解
2017/04/11 PHP
简单实现php上传文件功能
2017/09/21 PHP
php的单例模式及应用场景详解
2021/02/27 PHP
基于jQuery的倒计时实现代码
2012/05/30 Javascript
探寻JavaScript中this指针指向
2016/04/23 Javascript
JS上传组件FileUpload自定义模板的使用方法
2016/05/10 Javascript
微信JS-SDK坐标位置如何转换为百度地图坐标
2016/07/04 Javascript
AngularJS中指令的四种基本形式实例分析
2016/11/22 Javascript
JS中图片压缩的方法小结
2017/11/14 Javascript
微信小程序获取手机网络状态的方法【附源码下载】
2017/12/08 Javascript
Node.js API详解之 querystring用法实例分析
2020/04/29 Javascript
多页vue应用的单页面打包方法(内含打包模式的应用)
2020/06/11 Javascript
微信小程序实现点击生成随机验证码
2020/09/09 Javascript
聊聊vue 中的v-on参数问题
2021/01/29 Vue.js
Python下的Mysql模块MySQLdb安装详解
2014/04/09 Python
python执行等待程序直到第二天零点的方法
2015/04/23 Python
pymssql数据库操作MSSQL2005实例分析
2015/05/25 Python
python爬虫超时的处理的实例
2018/12/19 Python
PyQt打开保存对话框的方法和使用详解
2019/02/27 Python
详解python中sort排序使用
2019/03/23 Python
pandas的to_datetime时间转换使用及学习心得
2019/08/11 Python
django数据模型on_delete, db_constraint的使用详解
2019/12/24 Python
详解python 支持向量机(SVM)算法
2020/09/18 Python
python网络爬虫实现发送短信验证码的方法
2021/02/25 Python
HTML5 canvas基本绘图之填充样式实现
2016/06/27 HTML / CSS
大学理论知识学习自我鉴定
2014/04/28 职场文书
普通党员对照检查材料
2014/09/24 职场文书
2014年科普工作总结
2014/12/06 职场文书
培根随笔读书笔记
2015/07/01 职场文书
创业计划书之孕婴生活馆
2019/11/11 职场文书
Django实现在线无水印抖音视频下载(附源码及地址)
2021/05/06 Python
mysql 联合索引生效的条件及索引失效的条件
2021/11/20 MySQL