Extjs grid panel自帶滾動條失效的解決方法
之前用EXTJS的gridPanel組件的時候,因為經(jīng)常對gridPanel中的stroe數(shù)據(jù)進行過濾,所以有時候總是導(dǎo)致gridPanel自身所帶的scrollbar失效。

取個實例,EXTJS gridPanel自帶的滾動條,是有一個固定的列寬來放置這個scrollbar的,如上圖所示。所以當(dāng)這個scrollbar失效的時候,無論你怎么拖動這個滾動條,grid中的數(shù)據(jù)永遠(yuǎn)都不會隨scrollbar的移動而展示相應(yīng)區(qū)域的數(shù)據(jù)(換句話說就是你永遠(yuǎn)看到的數(shù)據(jù)都是截圖中的這幾條record)。
至于為什么gridpanel會失效?暫時也不清楚原因是什么。之前在Extjs的論壇和stackoverflow上都有人遇見類似的問題,但是版本可能是都是4.1之前的,Extjs的dev team說他們從4.1版本開始已經(jīng)修復(fù)了這個問題(不確定,希望用過4.1版本的童鞋論證下)。
好了,現(xiàn)在來說說怎么解決scrollbar失效。
xtype: 'gridpanel',
// autoScroll:true,
scroll:false,
viewConfig: {
style: { overflow: 'auto', overflowX: 'hidden' }
}
可以看到,禁用了autoScroll這個屬性,并且把scroll設(shè)置為false,然后設(shè)置viewConfig, 這里把橫向的滾動條給禁用了,只保留縱向的滾動條。OK 問題解決,看看效果:

這時會發(fā)現(xiàn)滾動條沒有了自己的固有列,而是和grid的最后一個列并在了一起,gridPanel自帶的scrollbar就這樣被禁用咯。
同時也解決了這個潛在的bug。
但是這種用法最好是將grid中的所有列都設(shè)置好固定的寬度,并且設(shè)置屬性:
resizable:false
這樣可以避免一些禁用橫向滾動條帶來的不必要麻煩。
相關(guān)文章
ExtJs GridPanel簡單的增刪改實現(xiàn)代碼
ExtJs GridPanel中實現(xiàn)增刪改效果的代碼,需要的朋友可以參考下。2010-08-08
Extjs3.0 checkboxGroup 動態(tài)添加item實現(xiàn)思路
Extjs3.0中的CheckboxGroup默認(rèn)不能動態(tài)添加item,如需要數(shù)據(jù)動態(tài)創(chuàng)建,試著創(chuàng)建整個CheckboxGroup,而不是動態(tài)添加item,具體實現(xiàn)如下,感興趣的朋友可以了解下2013-08-08
Extjs學(xué)習(xí)筆記之二 初識Extjs之Form
form恐怕是Web開發(fā)中最常用的控件了,Extjs對普通的html form進行了一些封裝,使其具有基本的外觀和一些簡便的和服務(wù)器進行通信的方法。2010-01-01
ExtJs 學(xué)習(xí)筆記 Hello World!
最近學(xué)ajax,接觸到了Extjs這個強大的框架。我想通過我的學(xué)習(xí)筆記,最后可以讓大家上手在項目中使用Ext。首先我會寫一些基本的用于入門Ext的文章,打好基礎(chǔ)是很重要的。2008-12-12
Extjs學(xué)習(xí)筆記之五 一個小細(xì)節(jié)renderTo和applyTo的區(qū)別
Extjs的組件有兩個看起來類似的配置項,applyTo和renderTo,這兩個配置項都是用來指定將該extjs組件加載到什么位置。那他們到底有什么區(qū)別呢,網(wǎng)上搜了下,有兩篇博文也是關(guān)于這個的。2010-01-01

