這篇文章給大家介紹怎么在Vue.js中使用全局事件,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
mixin 文件代碼
// event-mixin.js
export default {
created() {
if (this.$options.events) {
Object.keys(this.$options.events).forEach(key => {
let handler = this.$options.events[key]
if (typeof handler === 'string') {
handler = this[handler]
}
this[key + '::handler'] = handler.bind(this)
this.$root.$on('global::' + key, this[key + '::handler'])
})
}
},
beforeDestroy() {
if (this.$options.events) {
Object.keys(this.$options.events).forEach(key => {
this.$root.$off('global::' + key, this[key + '::handler'])
})
}
}
}使用前先在 main.js 中調用 mixin
Vue.mixin(require('./event-mixin.js').default)
在各個組件中,向 $root 發送事件即可
// a.vue
export default {
name: 'a',
events: {
'evt.a': 'handlerA',
'evt.b'() {
console.log('B triggered')
}
},
methods: {
handlerA() {
console.log('A triggered')
}
}
}// b.vue
export default {
name: 'b',
events: {
'evt.b'() {
console.log('B triggered again')
}
}
}// c.vue
export default {
name: 'c',
created() {
this.$root.$emit('global::evt.a') // 'A triggered'
this.$root.$emit('global::evt.b', 'data') // 'B triggered', 'B triggered again'
// 使用以上方式觸發,也可以在 mixin 中向實例添加專用觸發方法
}
}關于怎么在Vue.js中使用全局事件就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。