亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

怎么在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

孝感市| 铜川市| 三穗县| 登封市| 甘南县| 大连市| 五华县| 且末县| 长宁县| 临漳县| 漠河县| 瓦房店市| 无为县| 安宁市| 汉源县| 公安县| 万荣县| 宝鸡市| 保山市| 绵阳市| 新密市| 布尔津县| 仁寿县| 诸暨市| 尚志市| 三亚市| 石门县| 翼城县| 鄂州市| 交城县| 淳化县| 郯城县| 马龙县| 西青区| 平乡县| 洪泽县| 石城县| 鲁山县| 东方市| 津市市| 南部县|