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

淺析Vue.js中$emit和$on的用法和區(qū)別

 更新時(shí)間:2023年07月21日 11:13:18   作者:程序媛-徐師姐  
在?Vue.js?中,$emit和$on方法是兩個(gè)常用的方法,用于實(shí)現(xiàn)組件間的通信,雖然它們的名字很相似,但它們的作用和用法有所不同,本文將介紹$emit和$on方法的區(qū)別,并通過(guò)代碼示例來(lái)說(shuō)明它們的用法,感興趣的朋友可以參考下

Vue.js 中的 $emit 和 $on 方法有什么區(qū)別?

$emit

$emit 方法是 Vue.js 中用于觸發(fā)自定義事件的方法。它可以讓我們?cè)谝粋€(gè)組件中觸發(fā)一個(gè)自定義事件,并向父組件或祖先組件派發(fā)這個(gè)事件。在觸發(fā)事件時(shí),我們可以傳遞任意數(shù)量的參數(shù),這些參數(shù)可以在監(jiān)聽事件的組件中獲取到。

下面是一個(gè)使用 $emit 方法的示例代碼:

// 定義一個(gè)名為 myButton 的組件
Vue.component('my-button', {
  template: `
    <button @click="onClick">Click me</button>
  `,
  methods: {
    onClick: function () {
      this.$emit('clicked', 'Hello, world!')
    }
  }
})
// 定義一個(gè)名為 myApp 的組件,并在其中監(jiān)聽 myButton 組件的 clicked 事件
Vue.component('my-app', {
  template: `
    <div>
      <my-button @clicked="onButtonClicked"></my-button>
      <p>{{ message }}</p>
    </div>
  `,
  data: function () {
    return {
      message: ''
    }
  },
  methods: {
    onButtonClicked: function (msg) {
      this.message = msg
    }
  }
})

在上面的代碼中,我們定義了一個(gè)名為 myButton 的組件。這個(gè)組件中有一個(gè)按鈕,當(dāng)用戶點(diǎn)擊按鈕時(shí),會(huì)觸發(fā)一個(gè)名為 clicked 的自定義事件,并將字符串 ‘Hello, world!’ 作為參數(shù)傳遞給事件處理函數(shù)。

然后,我們定義了一個(gè)名為 myApp 的組件,并在其中監(jiān)聽 myButton 組件的 clicked 事件。當(dāng) myButton 組件觸發(fā) clicked 事件時(shí),myApp 組件中的 onButtonClicked 方法就會(huì)被調(diào)用,并將傳遞給事件處理函數(shù)的參數(shù)賦值給組件中的 message 數(shù)據(jù),從而更新視圖。

需要注意的是,$emit 方法只能向父組件或祖先組件派發(fā)事件,不能向子組件或后代組件派發(fā)事件。這是因?yàn)?Vue.js 中的事件傳遞是基于 DOM 樹的,父組件可以通過(guò) props 將數(shù)據(jù)傳遞給子組件,但是子組件不能直接向父組件傳遞數(shù)據(jù)。

$on

$on 方法是 Vue.js 中用于監(jiān)聽自定義事件的方法。它可以讓我們?cè)谝粋€(gè)組件中監(jiān)聽一個(gè)自定義事件,并在事件觸發(fā)時(shí)執(zhí)行一個(gè)回調(diào)函數(shù)。在監(jiān)聽事件時(shí),我們可以指定一個(gè)可選的參數(shù),用于限制事件的作用域,使得事件只在指定的組件中有效。

下面是一個(gè)使用 $on 方法的示例代碼:

// 定義一個(gè)名為 myButton 的組件,并在其中觸發(fā)一個(gè) clicked 事件
Vue.component('my-button', {
  template: `
    <button @click="onClick">Click me</button>
  `,
  methods: {
    onClick: function () {
      this.$emit('clicked', 'Hello, world!')
    }
  },
  created: function () {
    this.$emit('clicked', 'Hello, world!')
  }
})
// 定義一個(gè)名為 myApp 的組件,并在其中監(jiān)聽 myButton 組件的 clicked 事件
Vue.component('my-app', {
  template: `
    <div>
      <my-button></my-button>
      <p>{{ message }}</p>
    </div>
  `,
  data: function () {
    return {
      message: ''
    }
  },
  created: function () {
    this.$on('clicked', this.onButtonClicked)
  },
  methods: {
    onButtonClicked: function (msg) {
      this.message = msg
    }
  }
})

在上面的代碼中,我們定義了一個(gè)名為 myButton 的組件,并在其中觸發(fā)一個(gè) clicked 事件。在 myApp 組件中,我們使用 $on 方法監(jiān)聽 myButton 組件的 clicked 事件,并指定該事件只在 myApp 組件中有效。當(dāng) myButton 組件觸發(fā) clicked 事件時(shí),myApp 組件的 onButtonClicked 方法就會(huì)被調(diào)用,并將傳遞給事件處理函數(shù)的參數(shù)賦值給組件中的 message 數(shù)據(jù),從而更新視圖。

需要注意的是,$on 方法只能監(jiān)聽已經(jīng)派發(fā)的事件,不能監(jiān)聽尚未派發(fā)的事件。因此,在上面的代碼中,我們?cè)?myButton 組件的 created 鉤子函數(shù)中手動(dòng)觸發(fā)了 clicked 事件,以便 myApp 組件可以監(jiān)聽到該事件。

區(qū)別

$emit和on方法的區(qū)別主要在于它們的作用和用法。 on方法的區(qū)別主要在于它們的作用和用法。on方法的區(qū)別主要在于它們的作用和用法。emit方法用于觸發(fā)自定義事件并向父組件或祖先組件派發(fā)該事件,而 on方法用于監(jiān)聽自定義事件并在事件觸發(fā)時(shí)執(zhí)行回調(diào)函數(shù)。 on方法用于監(jiān)聽自定義事件并在事件觸發(fā)時(shí)執(zhí)行回調(diào)函數(shù)。on方法用于監(jiān)聽自定義事件并在事件觸發(fā)時(shí)執(zhí)行回調(diào)函數(shù)。emit方法必須在組件內(nèi)部使用,而$on方法可以在任何地方使用,包括組件內(nèi)部和組件外部。

另外,$emit方法可以傳遞任意數(shù)量的參數(shù),而on方法只能傳遞一個(gè)參數(shù),這個(gè)參數(shù)就是事件處理函數(shù)在接收到事件時(shí)傳遞的數(shù)據(jù)。 on方法只能傳遞一個(gè)參數(shù),這個(gè)參數(shù)就是事件處理函數(shù)在接收到事件時(shí)傳遞的數(shù)據(jù)。on方法只能傳遞一個(gè)參數(shù),這個(gè)參數(shù)就是事件處理函數(shù)在接收到事件時(shí)傳遞的數(shù)據(jù)。emit方法只能向父組件或祖先組件派發(fā)事件,而$on方法可以監(jiān)聽任意組件派發(fā)的事件。

總結(jié)

$emit 和on方法是Vue . js中用于實(shí)現(xiàn)組件間通信的兩個(gè)重要方法。 on方法是Vue.js中用于實(shí)現(xiàn)組件間通信的兩個(gè)重要方法。on方法是Vue.js中用于實(shí)現(xiàn)組件間通信的兩個(gè)重要方法。emit方法用于觸發(fā)自定義事件并向父組件或祖先組件派發(fā)該事件,而on方法用于監(jiān)聽自定義事件并在事件觸發(fā)時(shí)執(zhí)行回調(diào)函數(shù)。on方法用于監(jiān)聽自定義事件并在事件觸發(fā)時(shí)執(zhí)行回調(diào)函數(shù)。on方法用于監(jiān)聽自定義事件并在事件觸發(fā)時(shí)執(zhí)行回調(diào)函數(shù)。emit方法必須在組件內(nèi)部使用,而on方法可以在任何地方使用,包括組件內(nèi)部和組件外部。 on方法可以在任何地方使用,包括組件內(nèi)部和組件外部。on方法可以在任何地方使用,包括組件內(nèi)部和組件外部。emit方法可以傳遞任意數(shù)量的參數(shù),而on方法只能傳遞一個(gè)參數(shù)。on方法只能傳遞一個(gè)參數(shù)。on方法只能傳遞一個(gè)參數(shù)。emit方法只能向父組件或祖先組件派發(fā)事件,而 $on 方法可以監(jiān)聽任意組件派發(fā)的事件。

在實(shí)際開發(fā)中,$emit和$on方法經(jīng)常被用來(lái)實(shí)現(xiàn)父子組件之間的數(shù)據(jù)傳遞和交互。通過(guò)熟練掌握這兩個(gè)方法的用法,我們可以更加靈活地組織組件間的關(guān)系,提高組件的復(fù)用性和可維護(hù)性。

以上就是淺析Vue.js中$emit和$on的用法和區(qū)別的詳細(xì)內(nèi)容,更多關(guān)于Vue.js中$emit和$on的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 在Vue應(yīng)用中處理404頁(yè)面的解決方法

    在Vue應(yīng)用中處理404頁(yè)面的解決方法

    在現(xiàn)代的單頁(yè)面應(yīng)用(SPA)中,404錯(cuò)誤是不可避免的,當(dāng)用戶訪問(wèn)一個(gè)無(wú)效的路由時(shí),我們希望能夠提供一個(gè)友好的404頁(yè)面,以改善用戶體驗(yàn),在這篇博客中,我們將探討如何在Vue應(yīng)用中處理404頁(yè)面,并提供示例代碼幫助你更好地理解這一過(guò)程,需要的朋友可以參考下
    2024-12-12
  • elementUI Pagination 分頁(yè)指定最大頁(yè)的問(wèn)題及解決方法(page-count)

    elementUI Pagination 分頁(yè)指定最大頁(yè)的問(wèn)題及解決方法(page-count)

    項(xiàng)目中遇到數(shù)據(jù)量大,查詢的字段多,但用戶主要使用的是最近的一些數(shù)據(jù),1萬(wàn)條以后的數(shù)據(jù)一般不使用,這篇文章主要介紹了elementUI Pagination 分頁(yè)指定最大頁(yè)的問(wèn)題及解決方法(page-count),需要的朋友可以參考下
    2024-08-08
  • vue3中如何獲取proxy包裹的數(shù)據(jù)

    vue3中如何獲取proxy包裹的數(shù)據(jù)

    這篇文章主要介紹了vue3中如何獲取proxy包裹的數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue.js實(shí)現(xiàn)備忘錄功能

    Vue.js實(shí)現(xiàn)備忘錄功能

    這篇文章主要為大家詳細(xì)介紹了Vue.js實(shí)現(xiàn)備忘錄功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • vue使用H5的audio標(biāo)簽問(wèn)題

    vue使用H5的audio標(biāo)簽問(wèn)題

    這篇文章主要介紹了vue使用H5的audio標(biāo)簽問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue中對(duì)象的賦值Object.assign({}, row)方式

    vue中對(duì)象的賦值Object.assign({}, row)方式

    這篇文章主要介紹了vue中對(duì)象的賦值Object.assign({}, row)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue項(xiàng)目中將element-ui table表格寫成組件的實(shí)現(xiàn)代碼

    vue項(xiàng)目中將element-ui table表格寫成組件的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue項(xiàng)目中將element-ui table表格寫成組件的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-06-06
  • Vue-Router2.X多種路由實(shí)現(xiàn)方式總結(jié)

    Vue-Router2.X多種路由實(shí)現(xiàn)方式總結(jié)

    下面小編就為大家分享一篇Vue-Router2.X多種路由實(shí)現(xiàn)方式總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02
  • Vue3的動(dòng)態(tài)組件使用場(chǎng)景與示例

    Vue3的動(dòng)態(tài)組件使用場(chǎng)景與示例

    在 Vue 中,組件是構(gòu)建用戶界面的基礎(chǔ),而動(dòng)態(tài)組件的引入,更是讓開發(fā)者能夠在應(yīng)用中實(shí)現(xiàn)靈活、可重用的視圖邏輯,本文將探討 Vue 3 中的動(dòng)態(tài)組件,分享其使用場(chǎng)景,并通過(guò)示例代碼來(lái)說(shuō)明其操作方法,需要的朋友可以參考下
    2025-01-01
  • 全面解析Vue中的$nextTick

    全面解析Vue中的$nextTick

    這篇文章主要介紹了Vue中的$nextTick的相關(guān)資料,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2020-12-12

最新評(píng)論