Vue父子组件通信之$emit(基于vue2.5,ES6)

2018-06-07  本文已影响285人  兔子不打地鼠打代码

一、$emit的作用

在Vue中,父组件监听子组件触发的事件,需要在子组件用使用 $emit 触发,在父组件中使用 v-on: / @ 自定义事件监听。

二、有几点必须非常注意:

1、 vm.$emit( eventName, […args] ) 可以有两个参数;第一个参数必填,触发当前实例上的函数;第二个参数选填,是向函数传递的数据。

2、在vue中,事件名不存在自动化的大小写转换,触发事件名需要完全匹配监听这个事件所用的名称(驼峰就必须驼峰,短横线就必须短横线。)

3、父组件监听子组件触发的事件,不能用$on侦听子组件抛出的事件,而必须在模板里直接用v-on绑定子组件的事件。

三、现在我们一起来看看个例子吧(基于 vue: 2.5.2,ES2015)

【父组件】

<template>
  <div>
    <magic-eight-ball  @give-advice="showAdvice">
    </magic-eight-ball>
  </div>
</template>

<script>
import MagicEightBall from "../components/level2"

export default {
  methods:{
    showAdvice(advice){
      alert(advice)
    },
  },
  components:{
    MagicEightBall,
  },}
</script>

【子组件】

<template>
  <button @click="giveAdvice">
    click me for random alert
  </button>
</template>

<script>
  export default {
    data () {
      return {
        possibleAdvice:['num1','numb2','number3']}
    },
    methods:{
      giveAdvice(){
        let randomAdviceIndex = Math.floor(Math.random()
          *this.possibleAdvice.length);
        this.$emit('give-advice',
           this.possibleAdvice[randomAdviceIndex])
      }
    }
  }
</script>

四、解析代码

五、最后的呈现效果

点击按钮



出现弹框,内容在num1、numb2、number3里随机。


上一篇下一篇

猜你喜欢

热点阅读