欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue中$bus的用法及$on、$off的使用說明

 更新時(shí)間:2022年05月30日 09:09:01   作者:AALP  
這篇文章主要介紹了Vue中$bus的用法及$on、$off的使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

$bus的用法及$on、$off的使用

Vue中 $bus一般與 $on、 $off連用,一般用在任意組件間的通訊,所以今天就一起說,這里給大家舉一個(gè)案例

首先在main.js中配置全局總線 

//引入Vue
import Vue from 'vue'
//引入App
import App from './App.vue'
//關(guān)閉Vue的生產(chǎn)提示
Vue.config.productionTip = false
//創(chuàng)建vm
new Vue({
?? ?el:'#app',
?? ?render: h => h(App),
?? ?beforeCreate(){ ? ? ? ? ? ? ? ? //在初始化階段前
?? ??? ?Vue.prototype.$bus = this ? //配置全局總線,bus有總線的意思
?? ?}
})

在Student組件中提供數(shù)據(jù)給另一個(gè)組件(School組件)

<template>
?? ?<div class="student">
?? ??? ?<h2>學(xué)生姓名:{{name}}</h2>
?? ??? ?<h2>學(xué)生性別:{{sex}}</h2>
?? ??? ?<button @click="sendStudentName">把學(xué)生名給School組件</button>
?? ?</div>
</template>
<script>
?? ?export default {
?? ??? ?name:'Student',
?? ??? ?data() {
?? ??? ??? ?return {
?? ??? ??? ??? ?name:'張三',
?? ??? ??? ??? ?sex:'男',
?? ??? ??? ?}
?? ??? ?},
?? ??? ?methods: {
?? ??? ??? ?sendStudentName(){ ? ? ? ?//提供發(fā)送數(shù)據(jù)
?? ??? ??? ??? ?this.$bus.$emit('hello',this.name)
?? ??? ??? ?}
?? ??? ?},
?? ?}
</script>

在School組件中使用事件總線,接收數(shù)據(jù)。School組件想接收數(shù)據(jù),則在School組件中給 $bus綁定事件,事件的回調(diào)則留在School組件自身。

<template>
?? ?<div class="school">
?? ??? ?<h2>學(xué)校名稱:{{name}}</h2>
?? ??? ?<h2>學(xué)校地址:{{address}}</h2>
?? ?</div>
</template>
<script>
?? ?export default {
?? ??? ?name:'School',
?? ??? ?data() {
?? ??? ??? ?return {
?? ??? ??? ??? ?name:'工程學(xué)院',
?? ??? ??? ??? ?address:'重慶巴南',
?? ??? ??? ?}
?? ??? ?},
?? ??? ?mounted() {
?? ??? ??? ?this.$bus.$on('hello',(data)=>{ ? ? ?//綁定當(dāng)前事件(這里以hello為例)
?? ??? ??? ??? ?console.log('我是School組件,收到了數(shù)據(jù)',data)
?? ??? ??? ?})
?? ??? ?},
?? ??? ?beforeDestroy(){ ? ? ? ?//收尾操作,銷毀
?? ??? ??? ?this.$bus.$off('hello') ?//$off解綁當(dāng)前組件所用到的事件
?? ??? ?}
?? ?}
</script>

到這里已經(jīng)結(jié)束了,再給一個(gè)App組件,大家可以試一試這個(gè)案例

<template>
?? ?<div class="app">
?? ??? ?<School/>
?? ??? ?<Student/>
?? ?</div>
</template>
<script>
?? ?import Student from './components/Student'
?? ?import School from './components/School'
?? ?export default {
?? ??? ?name:'App',
?? ??? ?components:{School,Student},
?? ?}
</script>

vue實(shí)例事件總結(jié)($on,$once,$off,$emit)

1.什么是實(shí)例事件?

實(shí)例事件就是在構(gòu)造器外部調(diào)用構(gòu)造器內(nèi)部的數(shù)據(jù)。

2.使用場(chǎng)景

比如構(gòu)造器已經(jīng)有一個(gè)加的方法,現(xiàn)在領(lǐng)導(dǎo)說還要做一個(gè)減的方法,而我又不想動(dòng)構(gòu)造器里面的信息,那就可以使用實(shí)例事件了.操作如下:

在這里插入圖片描述

3.與$on對(duì)應(yīng)的還有一個(gè)$once 

 

上述代碼只改一個(gè)單詞$once

 app.$once('reduce',function(){
          console.log("減的方法觸發(fā)了");
          this.num--
      })

結(jié)果:減的方法只執(zhí)行一次.

4.$off關(guān)閉實(shí)例事件

關(guān)閉reduce后,減就失效了.

在這里插入圖片描述

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解vue的Des加密解密

    詳解vue的Des加密解密

    這篇文章主要為大家介紹了vue的Des加密解密使用實(shí)例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Vue實(shí)現(xiàn)簡(jiǎn)易跑馬燈效果

    Vue實(shí)現(xiàn)簡(jiǎn)易跑馬燈效果

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)簡(jiǎn)易跑馬燈效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Vue body樣式修改方式

    Vue body樣式修改方式

    這篇文章主要介紹了Vue body樣式修改方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue項(xiàng)目多環(huán)境配置(.env)的實(shí)現(xiàn)

    vue項(xiàng)目多環(huán)境配置(.env)的實(shí)現(xiàn)

    最常見的多環(huán)境配置,就是開發(fā)環(huán)境配置,和生產(chǎn)環(huán)境配置,本文主要介紹了vue項(xiàng)目多環(huán)境配置的實(shí)現(xiàn),感興趣的可以了解一下
    2021-07-07
  • Vue語法和標(biāo)簽的入門使用教程

    Vue語法和標(biāo)簽的入門使用教程

    Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式框架,下面這篇文章主要給大家介紹了關(guān)于Vue語法和標(biāo)簽使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • vue父組件傳值子組件報(bào)錯(cuò)Avoid?mutating?a?prop?directly解決

    vue父組件傳值子組件報(bào)錯(cuò)Avoid?mutating?a?prop?directly解決

    這篇文章主要為大家介紹了vue父組件傳值子組件報(bào)錯(cuò)Avoid?mutating?a?prop?directly解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • 淺析vue偵測(cè)數(shù)據(jù)的變化之基本實(shí)現(xiàn)

    淺析vue偵測(cè)數(shù)據(jù)的變化之基本實(shí)現(xiàn)

    這里涉及到Vue一個(gè)重要特性:響應(yīng)式系統(tǒng)。數(shù)據(jù)模型只是普通的 JavaScript對(duì)象,當(dāng)我們修改時(shí),視圖會(huì)被更新,而變化偵測(cè)是響應(yīng)式系統(tǒng)的核心
    2021-06-06
  • vue實(shí)現(xiàn)監(jiān)控視頻直播的示例代碼

    vue實(shí)現(xiàn)監(jiān)控視頻直播的示例代碼

    本文主要介紹了vue實(shí)現(xiàn)監(jiān)控視頻直播的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • Vue如何實(shí)現(xiàn)iframe的上一步、下一步操作

    Vue如何實(shí)現(xiàn)iframe的上一步、下一步操作

    這篇文章主要介紹了Vue如何實(shí)現(xiàn)iframe的上一步、下一步操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vue中addEventListener()?監(jiān)聽事件案例講解

    Vue中addEventListener()?監(jiān)聽事件案例講解

    這篇文章主要介紹了Vue中addEventListener()?監(jiān)聽事件案例講解,包括語法講解和事件冒泡或事件捕獲的相關(guān)知識(shí),本文結(jié)合示例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下
    2022-12-12

最新評(píng)論