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

Vue組件通信的四種方式匯總

 更新時間:2018年02月08日 08:28:52   作者:ziwei3749  
這篇文章主要給大家介紹了關(guān)于Vue組件通信的四種方式,分別是父子組件通信、非父子組件的eventBus通信、利用localStorage或者sessionStorage以及利用Vuex等方法,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。

前言

眾所周知vue是一種mvvm框架,它相對于jquery可能比較大的差異點(diǎn)之一就在于組件之間的通信了。本文重點(diǎn)是梳理了前兩個,父子組件通信和eventBus通信,我覺得Vue文檔里的說明還是有一些簡易,我自己第一遍是沒看明白。

  • 父子組件的通信
  • 非父子組件的eventBus通信
  • 利用本地緩存實現(xiàn)組件通信
  • Vuex通信

第一種通信方式:父子組件通信

父組件向子組件傳遞數(shù)據(jù)

父組件一共需要做4件事

      1.import son from './son.js' 引入子組件 son

      2.在components : {"son"} 里注冊所有子組件名稱

      3.在父組件的template應(yīng)用子組件, <son></son>

      4.如果需要傳遞數(shù)據(jù)給子組件,就在template模板里寫 <son :num="number"></son>

 // 1.引入子組件 
 import counter from './counter'
 import son from './son'
// 2.在ccmponents里注冊子組件
 components : {
 counter,
 son
 },
// 3.在template里使用子組件
 <son></son>
 // 4.如果需要傳遞數(shù)據(jù),也是在templete里寫
 <counter :num="number"></counter>

子組件只需要做1件事

      1.用props接受數(shù)據(jù),就可以直接使用數(shù)據(jù)

      2.子組件接受到的數(shù)據(jù),不能去修改。如果你的確需要修改,可以用計算屬性,或者把數(shù)據(jù)賦值給子組件data里的一個變量

 // 1.用Props接受數(shù)據(jù)
 props: [
  'num'
  ],
// 2.如果需要修改得到的數(shù)據(jù),可以這樣寫
 props: [
  'num'
 ],
 data () {
 return {
  number : this.num
 }
 },

子組件向父組件傳遞數(shù)據(jù)

父組件一共需要做2件事情

在template里定義事件

在methods里寫函數(shù),監(jiān)聽子組件的事件觸發(fā)

// 1. 在templete里應(yīng)用子組件時,定義事件changeNumber
 <counter :num="number"
   @changeNumber="changeNumber"
 >
 </counter>
// 2. 用changeNumber監(jiān)聽事件是否觸發(fā)
 methods: {
  changeNumber(e){
  console.log('子組件emit了',e);
  this.number = e
  },
 }

子組件一共需要1件事情

在數(shù)據(jù)變化后,用$emit觸發(fā)即可

// 1. 子組件在數(shù)據(jù)變化后,用$emit觸發(fā)即可,第二個參數(shù)可以傳遞參數(shù)
 methods: {
  increment(){
   this.number++
   this.$emit('changeNumber', this.number)
  },
 }

第二種通信方式: eventBus

eventBus這種通信方式,針對的是非父子組件之間的通信,它的原理還是通過事件的觸發(fā)和監(jiān)聽。

但是因為是非父子組件的關(guān)系,他們需要有一個中間組件來連接。

我是使用的通過在根組件,也就是#app組件上定義了一個所有組件都可以訪問到的組件,具體使用方式如下

使用eventBus傳遞數(shù)據(jù),我們一共需要做3件事情

      1.給app組件添加Bus屬性 (這樣所有組件都可以通過this.$root.Bus訪問到它,而且不需要引入任何文件)

      2.在組件1里,this.$root.Bus.$emit觸發(fā)事件

      3.在組件2里,this.$root.Bus.$on監(jiān)聽事件

// 1.在main.js里給app組件,添加bus屬性
import Vue from 'vue'
new Vue({
 el: '#app',
 components: { App },
 template: '<App/>',
 data(){
 return {
 Bus : new Vue()
 }
 }
})
// 2.在組件1里,觸發(fā)emit
increment(){
 this.number++
 this.$root.Bus.$emit('eventName', this.number)
 },
// 3.在組件2里,監(jiān)聽事件,接受數(shù)據(jù)
mounted(){
 this.$root.Bus.$on('eventName', value => {
 this.number = value
 console.log('busEvent');
 })
},

第三種通信方式: 利用localStorage或者sessionStorage

這種通信比較簡單,缺點(diǎn)是數(shù)據(jù)和狀態(tài)比較混亂,不太容易維護(hù)。

通過window.localStorage.getItem(key) 獲取數(shù)據(jù)

通過window.localStorage.setItem(key,value) 存儲數(shù)據(jù)

注意:JSON.parse() / JSON.stringify() 做數(shù)據(jù)格式轉(zhuǎn)換。

第四種通信方式: 利用Vuex

Vuex比較復(fù)雜,可以單獨(dú)寫一篇

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • 詳解基于 Nuxt 的 Vue.js 服務(wù)端渲染實踐

    詳解基于 Nuxt 的 Vue.js 服務(wù)端渲染實踐

    這篇文章主要介紹了詳解基于 Nuxt 的 Vue.js 服務(wù)端渲染實踐,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • 通過GASP讓vue實現(xiàn)動態(tài)效果實例代碼詳解

    通過GASP讓vue實現(xiàn)動態(tài)效果實例代碼詳解

    GASP是一個JavaScript動畫庫,它支持快速開發(fā)高性能的 Web 動畫。GASP 使我們能夠輕松輕松快速的將動畫串在一起,來創(chuàng)造一個高內(nèi)聚的流暢動畫序列。這篇文章主要介紹了通過GASP讓vue實現(xiàn)動態(tài)效果,需要的朋友可以參考下
    2019-11-11
  • vuex中store存儲store.commit和store.dispatch的區(qū)別及說明

    vuex中store存儲store.commit和store.dispatch的區(qū)別及說明

    這篇文章主要介紹了vuex中store存儲store.commit和store.dispatch的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue組件模板的幾種書寫形式(3種)

    Vue組件模板的幾種書寫形式(3種)

    這篇文章主要介紹了Vue組件模板的幾種書寫形式(3種),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • vue3組合式API中setup()概念和reactive()函數(shù)的用法

    vue3組合式API中setup()概念和reactive()函數(shù)的用法

    這篇文章主要介紹了vue3組合式API中setup()概念和reactive()函數(shù)的用法,接下來的事件,我將帶著你從淺到深分析為什么我們需要學(xué)習(xí)組合式API以及我們的setup()函數(shù)作為入口函數(shù)的一個基本的使用方式,需要的朋友可以參考下
    2023-03-03
  • Vue3實現(xiàn)word轉(zhuǎn)成pdf代碼的方法

    Vue3實現(xiàn)word轉(zhuǎn)成pdf代碼的方法

    在Vue 3中,前端無法直接將Word文檔轉(zhuǎn)換為PDF,因為Word文檔的解析和PDF的生成通常需要在后端進(jìn)行這篇文章主要介紹了Vue3實現(xiàn)word轉(zhuǎn)成pdf代碼的方法,需要的朋友可以參考下,
    2023-07-07
  • Vue3中SetUp函數(shù)的參數(shù)props、context詳解

    Vue3中SetUp函數(shù)的參數(shù)props、context詳解

    我們知道setup函數(shù)是組合API的核心入口函數(shù),下面這篇文章主要給大家介紹了關(guān)于Vue3中SetUp函數(shù)的參數(shù)props、context的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • element-ui自定義message-box自定義樣式不生效的解決

    element-ui自定義message-box自定義樣式不生效的解決

    這篇文章主要介紹了element-ui自定義message-box自定義樣式不生效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue環(huán)境搭建簡單教程

    vue環(huán)境搭建簡單教程

    這篇文章主要介紹了vue環(huán)境搭建簡單教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Vue.js watch監(jiān)視屬性知識點(diǎn)總結(jié)

    Vue.js watch監(jiān)視屬性知識點(diǎn)總結(jié)

    在本篇文章里小編給大家分享的是關(guān)于Vue.js watch監(jiān)視屬性的相關(guān)知識點(diǎn)內(nèi)容,需要的朋友們學(xué)習(xí)下。
    2019-11-11

最新評論