在vue中,「$emit」用來觸發目前實例上的事件,附近參數都會傳給監聽器回呼;子元件可以利用「$emit」觸發父元件的自訂事件,語法為「vm.$emit( event, […args] )」。
本文操作環境:windows10系統、Vue2.9.6版,DELL G3電腦。
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='select(`大连`)'>点击此处将‘大连’发射给父组件</button> </div> </template> <script> export default { name:'trainCity', props:['sendData'], // 用来接收父组件传给子组件的数据 methods:{ select(val) { let data = { cityname: val }; this.$emit('showCityName',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:'index', components: {TrainCity}, data () { return { toCity:"北京" } }, methods:{ updateCity(data){//触发子组件城市选择-选择城市的事件 this.toCity = data.cityname;//改变了父组件的值 console.log('toCity:'+this.toCity) } } } </script>
【相關推薦:《vue.js教學
以上是vue中$emit的用法是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!