ExtJs实践(5)——解决在GridPanel中使用bbar或者tbar的分页条的宽度自适应问题...

        在GridPanel中利用bbar或者tbar来完成分页功能,是个很常见的做法,但是这里发现一个问题,就是宽度不能够自适应。首先我们看下这样的源代码:

ExpandedBlockStart.gif 代码
var  store  =   new  Ext.data.Store({ 
    proxy: 
new  Ext.data.ScriptTagProxy({ url: main_domain  +  page._handlers[ ' enterprise ' +   ' getList '  }), 
    
// proxy: new Ext.data.HttpProxy({ url: page._handlers['enterprise'] + 'getList' }), 
    reader:  new  Ext.data.JsonReader({ 
        totalProperty: 
' TotalProperty '
        root: 
' List '  
    }, [ 
        { name: 
' Id '  }, 
        { name: 
' Code '  }, 
        { name: 
' Name '  }, 
        { name: 
' CreateTime '  } 
    ]) 
    
// sortInfo: { field: "Name", direction: "ASC" } 
}); 
store.load({ params: { start: 
0 , limit:  5 } });
var  selModel  =   new  Ext.grid.CheckboxSelectionModel();
var  grid  =   new  Ext.grid.GridPanel({ 
    renderTo: 
' gridEnterprise '
    stripeRows: 
true //  斑马线效果 
     // width:'100%', 
    autoHeight:  true
    autoWidth: 
true
    loadMask: 
true
    
//             frame: true, 
     //             autoExpandColumn: 'Id', 
     //             columnLines: true, 
    store: store, 
    selModel: selModel, 
    columns: [ 
        
new  Ext.grid.RowNumberer(), 
        selModel, 
        { header: 
' 编号 ' , dataIndex:  ' Id ' , sortable:  true  }, 
        { header: 
' Code ' , dataIndex:  ' Code ' , sortable:  true  }, 
        { header: 
' 企业名称 ' , dataIndex:  ' Name ' , sortable:  true  }, 
        { header: 
' 开户日期 ' , dataIndex:  ' CreateTime ' , sortable:  true  } 
    ], 
    viewConfig: { 
        enableRowBody: 
true  
        
// forceFit: true 
    } 
    bbar: 
new  Ext.PagingToolbar({ 
        pageSize: 
5
        store: store, 
        displayInfo: 
true
        displayMsg: 
' 显示第 {0} 条到 {1} 条记录,一共 {2} 条 '
        emptyMsg: 
" 没有记录 "  
    }) 
});

其中可以看到bbar作为底部工具栏,显示分页工具条。运行中代码。

image

发现底部没有随着浏览器尺寸的拖动而自适应。

这个问题今天被纠结了很久~先后用width:100%或者CSS去调整样式,都失败了。后来在Ext.all.debug.js的框架中找到一个onResize的事件,只要浏览器尺寸改变,就会触发该事件:

ExpandedBlockStart.gif 代码
onResize:  function  (adjWidth, adjHeight, rawWidth, rawHeight) { 
    
var  w  =  adjWidth, 
        h 
=  adjHeight;
    
if  (Ext.isDefined(w)  ||  Ext.isDefined(h)) { 
        
if  ( ! this .collapsed) {
            
if  (Ext.isNumber(w)) { 
                
this .body.setWidth(w  =   this .adjustBodyWidth(w  -   this .getFrameWidth())); 
            } 
else   if  (w  ==   ' auto ' ) { 
                w 
=   this .body.setWidth( ' auto ' ).dom.offsetWidth; 
            } 
else  { 
                w 
=   this .body.dom.offsetWidth; 
            }
             if  ( this .tbar) { 
                
this .tbar.setWidth(w); 
                
if  ( this .topToolbar) { 
                    
this .topToolbar.setSize(w); 
                } 
            } 
            
if  ( this .bbar) { 
                
this .bbar.setWidth(w); 
                
if  ( this .bottomToolbar) { 
                    
this .bottomToolbar.setSize(w);
                    
if  (Ext.isIE) { 
                        
this .bbar.setStyle( ' position ' ' static ' ); 
                        
this .bbar.setStyle( ' position ' '' ); 
                    } 
                } 
            }
   …
}

如果包含bbar或者tbar的话,就会重新设置浏览器调整过的宽度。于是,我把红色的部分注释掉,得到了解决。

 

     但是,我不想去修改Ext.all.debug.js的代码。因此,我建议在使用分页的时候,可以考虑多加一个分页的DIV层,比如:

< div  id ="gridEnterprise" ></ div >  
< div  id ="pager" ></ div >

然后修改脚本:

ExpandedBlockStart.gif 代码
var  pager  =   new  Ext.PagingToolbar({ 
    pageSize: 
5
    store: store, 
    displayInfo: 
true
    displayMsg: 
' 显示第 {0} 条到 {1} 条记录,一共 {2} 条 '
    emptyMsg: 
" 没有记录 "
    renderTo: 
' pager '  
});

这样问题也可以得到解决。

image

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值