ExtJS viewModel 向下傳遞

2021-09-11 05:16:49 字數 1637 閱讀 8170

在之前的文章講過全域性使用viewmodel,也講過浮動層的viewmodel雙向繫結,還有講過通過viewmodel繫結方法。

但是,對於viewmodel向下傳遞:子控制項bind父控制項viewmodel中的值,甚至孫子輩控制項中的某個屬性,bind爺爺輩控制項viewmodel中的值,效果如下圖(子控制項也可以更改父輩控制項viewmodel的值)

lookupviewmodel方法:

控制項物件.lookupviewmodel([skipthis]

);

[skipthis]

為true時,僅向上查詢該控制項父輩容器中的viewmodel ,不考慮自己的viewmodel

[skipthis]

為空時 即 控制項物件.lookupviewmodel();查詢該控制項的上級的viewmodel

而getviewmodel,是僅找自己例項的viewmodel,就是說用getviewmodel 哪個控制項配置了,哪個控制項能找到(下面**有解釋)

圖中,總共有四層控制項:

最外層container,他具有乙個頂層的viewmodel,其中isbrowser欄位用於向下傳遞以來控制子孫輩控制項的狀態

viewmodel: 

},

還有三個子控制項,其中在子控制項的button中 改變isbrowser的值

items: ['

},}, }, ]

這裡的container,就是第一層中的referencekey為secondct的子控制項container,他也具有乙個viewmodel,並且在此用defaultlistenerscope來限定作用域,在此作用域裡,宣告乙個方法onshow來進行改變第一層中viewmodel中isbrowser的值。

注意:在onshow中 this指的是當前的container,當前的container必須通過lookupviewmodel方法來進行向上查詢

},

onshow(sender)

}

也就是第二層的子集,裡面包含了第四層 就不再贅述

items: ['

},}, ,

},items: [, 按鈕'

},// text

style: 'border:2px solid green',

handler: function (sender)

}],onfourthshow(sender)

}],

前向星和鏈式前向星

我們首先來看一下什麼是前向星.前向星是一種特殊的邊集陣列,我們把邊集陣列中的每一條邊按照起點從小到大排序,如果起點相同就按照終點從小到大排序,並記錄下以某個點為起點的所有邊在陣列中的起始位置和儲存長度,那麼前向星就構造好了.用len i 來記錄所有以i為起點的邊在陣列中的儲存長度.用head i 記...

前向星和鏈式前向星

前向星 前向星是一種特殊的邊集陣列,我們把邊集陣列中的每一條邊按照起點從小到大排序,如果起點相同就按照終點從小到大排序,並記錄下以某個點為起點的所有邊在陣列中的起始位置。鏈式前向星 鏈式前向星其實就是靜態建立的鄰接表,時間效率為o m 空間效率也為o m 遍歷效率也為o m next表示當前結點的下...

前向星和鏈式前向星

1 前向星 前向星是以儲存邊的方式來儲存圖,先將邊讀入並儲存在連續的陣列中,然後按照邊的起點進行排序,這樣陣列中起點相等的邊就能夠在陣列中進行連續訪問了。它的優點是實現簡單,容易理解,缺點是需要在所有邊都讀入完畢的情況下對所有邊進行一次排序,帶來了時間開銷,實用性也較差,只適合離線演算法。圖一 2 ...