91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Vue.js中使用全局事件

發布時間:2021-03-25 16:17:48 來源:億速云 閱讀:480 作者:Leah 欄目:web開發

這篇文章給大家介紹怎么在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中使用全局事件就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

浑源县| 喜德县| 沙坪坝区| 长阳| 蓬溪县| 海晏县| 福泉市| 鹤壁市| 化隆| 靖宇县| 柳河县| 环江| 嵊州市| 马鞍山市| 和硕县| 邳州市| 临漳县| 龙川县| 潮安县| 宜良县| 自治县| 屯留县| 应用必备| 大洼县| 阳泉市| 汾西县| 玉屏| 高陵县| 噶尔县| 屯昌县| 郑州市| 康乐县| 天台县| 宁夏| 元阳县| 南康市| 阿尔山市| 游戏| 南安市| 武定县| 壶关县|