首頁 >web前端 >Vue.js >vue中$emit的用法是什麼

vue中$emit的用法是什麼

WBOY
WBOY原創
2022-03-17 11:31:416360瀏覽

在vue中,「$emit」用來觸發目前實例上的事件,附近參數都會傳給監聽器回呼;子元件可以利用「$emit」觸發父元件的自訂事件,語法為「vm.$emit( event, […args] )」。

vue中$emit的用法是什麼

本文操作環境:windows10系統、Vue2.9.6版,DELL G3電腦。

vue中$emit的用法是什麼

vue中使用$emit(eventName) 觸發事件

 $emit(eventName)  觸發目前實例上的事件,並附加參數都會傳給監聽器回呼。

使用 $emit(eventName) 觸發事件

Api 中的解釋:

vm.$emit( event, […args] )

vue中 關於$emit的用法

#1、父元件可以使用 props 把資料傳給子組件。

2、子元件可以使用 $emit 觸發父元件的自訂事件。

vm.$emit( event, arg ) //触发当前实例上的事件
vm.$on( event, fn );//监听event事件后运行 fn;

範例如下:

子元件

<template>  
  <div class="train-city">  
    <h3>父组件传给子组件的toCity:{{sendData}}</h3>   
    <br/><button @click=&#39;select(`大连`)&#39;>点击此处将‘大连’发射给父组件</button>  
  </div>  
</template>  
<script>  
  export default {  
    name:&#39;trainCity&#39;,  
    props:[&#39;sendData&#39;], // 用来接收父组件传给子组件的数据  
    methods:{  
      select(val) {  
        let data = {  
          cityname: val  
        };  
        this.$emit(&#39;showCityName&#39;,data);//select事件触发后,自动触发showCityName事件  
      }  
    }  
  }  
</script>

父元件:

<template>  
    <div>父组件的toCity{{toCity}}</div>  
    <train-city @showCityName="updateCity" :sendData="toCity"></train-city>  
<template>  
<script>  
  import TrainCity from "./train-city";  
  export default {  
    name:&#39;index&#39;,  
    components: {TrainCity},  
    data () {  
      return {  
        toCity:"北京"  
      }  
    },  
    methods:{  
      updateCity(data){//触发子组件城市选择-选择城市的事件  
        this.toCity = data.cityname;//改变了父组件的值  
        console.log(&#39;toCity:&#39;+this.toCity)  
      }  
    }  
  }  
</script>

【相關推薦:《vue.js教學

# 》】#######

以上是vue中$emit的用法是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn