目錄
父元件傳遞資料給子元件
首頁 web前端 js教程 4種Vue組件通訊方式實例分享

4種Vue組件通訊方式實例分享

Feb 07, 2018 pm 02:23 PM
實例 方式 溝通

本文主要和大家分享4種Vue元件通訊方式:父子元件的通訊、非父子元件的eventBus通訊、利用本機快取實作元件通訊、Vuex通訊。希望能幫助大家。

第一種通訊方式:父子元件通訊

父元件傳遞資料給子元件

  • #父元件總共需要做4件事

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

    • 2.在components : { "son"} 裡註冊所有子元件名稱

    • 3.在父元件的template應用子元件,

    • #4.如果需要傳遞資料給子元件,就在template模板裡寫

           
 // 1.引入子组件 
     import counter from './counter'     import son from './son'
登入後複製
// 2.在ccmponents里注册子组件    components : {
        counter,
        son
    },
登入後複製
           
// 3.在template里使用子组件   <son></son>
登入後複製
  • 子元件只需要做1件事

    • 1.用props接受資料,就可以直接使用資料

    • #1.用props接受資料,就可以直接使用資料

2.子元件接受到的資料,不能去修改。如果你的確需要修改,可以用計算屬性,或把資料賦值給子元件data裡的一個變數

  •            
     // 4.如果需要传递数据,也是在templete里写
     
       <counter :num="number"></counter>
    登入後複製
            #   
       // 1.用Props接受数据      props: [               'num'
               ],
    登入後複製
    ##子元件傳遞資料元件向父元件所示給父元件一樣給父元件

    子元件傳送資料給父元件
    • #子元件到子元件向父元件傳遞資料給父元件
    • #父元件總共需要做2件事
    • #在template裡定義事件
    ##在methods裡寫函數,監聽子組件的事件觸發
  •            
// 2.如果需要修改得到的数据,可以这样写
   props: [            'num'
        ],  data () {        return {
            number : this.num
        }
    },
登入後複製
           
// 1. 在templete里应用子组件时,定义事件changeNumber
      <counter :num="number"                 @changeNumber="changeNumber"
      >
      </counter>
登入後複製

思考

在資料變更後,用$emit觸發即可

           

// 2. 用changeNumber监听事件是否触发
        methods: {
            changeNumber(e){                console.log('子组件emit了',e);                this.number = e
            },
        }
登入後複製
第二種通訊方式: eventBus
  • #eventBus這種通訊方式,針對的是非父子組件之間的通信,它的原理還是透過事件的觸發和監聽。

    但是因為是非父子組件的關係,他們需要有一個中間組件來連接。
  • 我是使用的透過在根元件,也就是#app元件上定義了一個所有元件都可以存取的元件,具體使用方式如下

    使用eventBus傳遞資料,我們一共需要做3件事情
  • 1.給app元件添加Bus屬性(這樣所有元件都可以透過this.$root.Bus存取到它,而且不需要引入任何檔案)

2.在元件1裡,this.$root.Bus.$emit觸發事件


3.在元件2裡,this. $root.Bus.$on監聽事件

           
// 1. 子组件在数据变化后,用$emit触发即可,第二个参数可以传递参数
        methods: {
            increment(){                    this.number++                    this.$emit('changeNumber', this.number)
                },
        }
登入後複製
           
// 1.在main.js里给app组件,添加bus属性import Vue from 'vue'new Vue({
  el: '#app',
  components: { App },  template: '<App/>',
  data(){    return {
      Bus : new Vue()
    }
  }
})
登入後複製
       

// 2.在组件1里,触发emitincrement(){
        this.number++
        this.$root.Bus.$emit('eventName', this.number)
    },
登入後複製
 
// 3.在组件2里,监听事件,接受数据mounted(){    this.$root.Bus.$on('eventName', value => {        this.number = value
        console.log('busEvent');
    })
},
登入後複製
    中之前使用中這樣溝通方式)     #rrrereeesion#3 月來說明這種溝通方式:狀態比較混亂,不太容易維持。

透過window.localStorage.getItem(key) 取得資料
透過window.localStorage.setItem(key,value) 儲存資料

注意用JSON.parse() / JSON.stringify () 做資料格式轉換。

第四種通訊方式: 利用Vuex

Vuex比較複雜,可以單獨寫一篇

相關推薦:

Vue組件化開發經驗分享

######vue元件父與子通訊詳解############權限管理模組中動態載入Vue元件實例詳解### ###

以上是4種Vue組件通訊方式實例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

新一代光纖寬頻技術 ——50G PON 新一代光纖寬頻技術 ——50G PON Apr 20, 2024 pm 09:22 PM

上篇文章(連結),小棗君向大家介紹了寬頻技術從ISDN、xDSL到10GPON的發展歷程。今天,我們來聊聊即將到來的新一代光纖寬頻技術—50GPON。 █F5G和F5G-A介紹50GPON之前,先來談談F5G和F5G-A。 2020年2月,ETSI(歐洲電信標準化協會)推進了一套以10GPON+FTTR、Wi-Fi6、200G光傳送/匯聚、OXC等技術為基礎的固定通訊網路技術體系,並將其命名為F5G,也就是第五代固網通訊技術(The5thgenerationFixednetworks)。 F5G是固網

Vue與伺服器端通訊的刨析:如何處理斷網情況 Vue與伺服器端通訊的刨析:如何處理斷網情況 Aug 10, 2023 am 10:55 AM

Vue與伺服器端通訊的探析:處理斷網情況的策略引言:在現代Web開發中,Vue.js已成為廣泛使用的前端框架。然而,由於網路環境的不穩定性,處理斷網情況是一個需要我們考慮的重要議題。本文將分析如何在Vue中處理斷網情況,並給出對應的程式碼範例。一、斷網狀況分析在網路狀況較好的情況下,Vue可以透過Ajax請求或WebSocket與伺服器進行通訊。但是,

無線滑鼠的發展史 無線滑鼠的發展史 Jun 12, 2024 pm 08:52 PM

原文標題:《無線滑鼠到底是怎麼做到無線的? 》無線滑鼠慢慢成了現在辦公電腦的標配,從此再也不用拖著長長的線跑來跑去了。可是,無線滑鼠是怎麼運作的呢?今天我們一起來學習No.1無線滑鼠的發展史你知道嗎,無線滑鼠現在也已經40歲了,1984年的時​​候,羅技研製了世界上第一款無線滑鼠,不過這個無線滑鼠採用紅外線作為訊號的載體,據說長得像下面圖片這個樣子,後面因為效能原因而宣告失敗。直到十年後的1994年,羅技終於研發成功了一個工作在27MHz的無線滑鼠,這個27MHz頻率也成了很長一段時間內,無線滑鼠

寬頻上網技術簡史 寬頻上網技術簡史 Apr 16, 2024 am 09:00 AM

在現今這個數位時代,寬頻已經成為我們每個人、每個家庭的生活必需品。如果沒有它,我們會坐立難安、心緒不寧。那麼,你知道寬頻背後的技術原理嗎?從最早期的56k「貓」撥號,到現在的千兆城市、千兆家庭,我們的寬頻科技到底經歷了怎樣的改變?今天這篇文章,我們就來詳細了解一下—「寬頻的故事」。 █xDSL和ISDN下面這個介面,你看過嗎?我相信很多70後80後的小夥伴,肯定見過,非常熟悉。沒錯,這就是當年我們最初接觸網路時,進行「撥接上網」的介面。那還是20多年前,小棗君還在上大學的時候。為了上網,我

PHP實作Socket通訊的方法與技巧 PHP實作Socket通訊的方法與技巧 Mar 07, 2024 pm 02:06 PM

PHP是一種常用的開發語言,可以用來開發各種網頁應用程式。除了常見的HTTP請求和回應以外,PHP也支援透過Socket進行網路通信,實現更靈活和高效的資料互動。本文將介紹PHP如何實作Socket通訊的方法與技巧,並附上具體的程式碼範例。什麼是Socket通訊Socket是一種在網路中進行通訊的方法,可以在不同的電腦之間傳輸資料。透過S

長白山主峰可正常上網:吉林移動、中興通訊完成 2.6G + 700M 三載波聚合商用,峰值速率達 2.53Gbps 以上 長白山主峰可正常上網:吉林移動、中興通訊完成 2.6G + 700M 三載波聚合商用,峰值速率達 2.53Gbps 以上 Jul 25, 2024 pm 01:20 PM

7月25日訊息,吉林移動、中興通訊現已在長白山主峰完成基於2.6G頻段(100+60M)加700M頻段(30M)三載波聚合商用,現場測試峰值速率最高可達2.53Gbps以上。官方指出,長白山是中華十大名山之一,現為國家AAAAA級旅遊景區、世界地質公園、世界生物圈保護區、世界最佳自然保護地,2023年接待遊客數達到274.77萬人次,本次部署3CC將極大滿足用戶的網路需求。據介紹,吉林移動2024年初已經率先完成2.6G(100+60M)加4.9G(100M)頻段三載波組網載波聚合試點,下載峰值

諾基亞計劃以 1.85 億歐元的價格出售其設備管理和服務管理平台業務 諾基亞計劃以 1.85 億歐元的價格出售其設備管理和服務管理平台業務 Dec 21, 2023 am 08:07 AM

諾基亞今日宣布,將其設備管理和服務管理平台業務以1.85億歐元的價格出售給Lumine集團,預計明年第一季完成根據我們的調查發現,Lumine是一家通訊和媒體軟體公司,最近從ConstellationSoftware分拆出來。作為交易的一部分,預計會有大約500名諾基亞員工加入Lumine據公開資料顯示,這些平台的業務主要是諾基亞透過先前兩次收購Motive和mFormation形成的。 Lumine稱其有意恢復Motive品牌,並將其作為一個獨立的業務部門Lumine表示,收購價格包括一筆高達

學習Golang指標轉換的最佳實務範例 學習Golang指標轉換的最佳實務範例 Feb 24, 2024 pm 03:51 PM

Golang是一門功能強大且高效的程式語言,可用於開發各種應用程式和服務。在Golang中,指標是一種非常重要的概念,它可以幫助我們更靈活和有效率地操作資料。指標轉換是指在不同類型之間進行指標操作的過程,本文將透過具體的實例來學習Golang中指標轉換的最佳實踐。 1.基本概念在Golang中,每個變數都有一個位址,位址就是變數在記憶體中的位置。

See all articles