国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Vue組件通信實踐記錄(推薦)

2019-11-19 15:47:35
字體:
來源:轉載
供稿:網友

組件通信

幾乎所有的mvvm框架中都要涉及組件通信的功能(吐槽一下knockout,畢竟是鼻祖就先不說它了)。而且目前的前端形式來看,組件化是一個項目的基礎。所以選好一個合適的框架后,隨著組件的不斷增加,業務的復雜度提升,組件之間的通信變得尤為重要。

實踐方法

由于更換新的框架,我們的項目由Avalon更新成Vue.但是為了兼容以前的業務代碼,不能直接使用vue的標準實踐方式,我還是拿過來后封裝了一個vue的class,具體業務里面不影響使用,封裝的過程之后寫出來再聊吧,下面來總結一下最近用到的通信實踐方法。

1.父組件是通過props傳遞數據給子組件

vmodel 中包含了兩個子組件

<div class="w-base">  <book-component v-bind:bookdata="book"></book-component></div><div class="base">  <node-component v-bind:catalog="catalog" ></node-component></div>

在上面這段代碼中我們可以看到,定義了兩個子組件,并且使用指定v-bind指令傳遞了數據,子組件會接收到傳遞的數據。

Vue.component('book-component', { template: tpl,//可以傳進來子組件的模板文件 props: ['book'], data: function () {  return { myBook: this.bookdata } }})

建議接收到單向的props數據后,定義一個局部變量來初始化使用。

2.父組件與子組件之間通信的其他方式

vue中給實例提供了三個我們可用的API $children 和 $refs 以及 $parent 。

$children :當前實例的直接子組件。需要注意 $children 并不保證順序,也不是響應式的。

$refs :包含了當前實例所有擁有 ref 注冊的子組件的對象.

$parent : 當前實例的父實例。

所以說,如果在通信方面我們我組件想要調用子組件,能用的方法只有 $refs 了,因為 $children 是一個數組,并且不保證順序,也沒有相關的id去尋找我們需要的那個特定子組件。但是如果使用 $refs 去尋找特定子組件,那就必須要給那個子組件注冊 ref 。

父組件的模版

<!-- vm.$refs.child will be the child comp instance --><child-component ref="child"></child-comp>

父組件

//找到子組件并且調用它的方法var myChild = this.$refs.child;mymyChild.func();

子組件

//找到父組件并且調用它的方法var myParent = this.$parent;mymyChild.func();

3.平行組件之間的兩種通信方式

a.官方提供的事件bus

var bus = new Vue()// 觸發組件 A 中的事件bus.$emit('id-selected', 1)// 在組件 B 創建的鉤子中監聽事件bus.$on('id-selected', function (id) { // ...})

b.通過父組件去找兄弟組件

//找到父組件的$refs對象,然后找到組件的兄弟組件 var $refs = this.$parent?this.$parent.$refs:{}; var childComponent = $refs.child; //child為改組件的ref屬性值

其實以上兩種方法最好的實踐方式是封裝到項目的基類中,這樣不用每次都去定義一個空Vue()實例,而是每個實例的基類中都有這個事件bus。同樣可以封裝找到其他兄弟組件的方法,但是該兄弟組件必須注冊ref

下面這個方法是我在項目中封裝的用于找到父組件,然后再去找到兄弟組件的方法。

//平行組件之間的通信getComponentByRef: function(refId) {  var $refs = this.$parent?this.$parent.$refs:{};  for (var $id in $refs) {    if ($id == refId) {      return $refs[$id];    }  }  return null;}

使用

//在組件中直接使用this.getComponentByRef("booknode").updateNode(this.node);

4.組件間復雜數據通信Vuex

一說到vuex,很多剛開始接觸vue的人會主動避免去使用它,其實它并沒有想象中的那么復雜。最好的開始是引入vuex后,走一遍給出的小示例。但是如果你的項目并不復雜的話,可以不考慮狀態管理,那么什么時候需要使用狀態管理呢?

我們來看這樣一個布局

如果component1中的某個數據變更,那么com2,com3也要跟著更新,此時com3中又細分為了三個小組件。

問題:

  1. 多個試圖依賴同一個狀態
  2. 多層嵌套的組件,數據變更和代碼維護困難

那這樣的情況時,我們可以考慮使用狀態管理。下一篇文章將詳細講解關于vuex的實踐和理解。

寫在最后的總結

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 丽江市| 沾化县| 海安县| 黑龙江省| 墨竹工卡县| 金秀| 大英县| 怀化市| 浦北县| 彭泽县| 罗江县| 汨罗市| 科尔| 曲麻莱县| 沙河市| 舒城县| 南安市| 东辽县| 文水县| 大兴区| 呼图壁县| 泸水县| 海丰县| 台安县| 措勤县| 泗洪县| 富宁县| 姜堰市| 遂溪县| 剑川县| 特克斯县| 尉氏县| 郧西县| 淄博市| 岑溪市| 抚顺市| 贵溪市| 齐河县| 拉萨市| 永宁县| 莎车县|