解决Ext 4.0.7 tree.Panel横向不出滚动条,纵向滚动条失效的问题

/**
 * 重写Ext.tree.Panel afterlayout方法,解决横向不出滚动条,纵向滚动条失效的问题
 * 1.显示grid的css滚动条,对于树表横向滚动条没有办法使标题一块儿滚动,所以隐藏掉(在树表上定义属性treeGrid:'Y');
 * 2.将grid的css纵向滚动条定位到最右侧;
 * 3.获取到ext自动添加的自己写纵向的滚动条,将它remove掉;
 * 4.将remove掉改成设置宽度为0隐藏掉。
 * 遗留问题:
 *         remove掉会造成grid页面数据新增时,无法定位新增行。
 *         宽度设置为0会造成:鼠标滚轮可能会失效,需要鼠标左键拖动滚动条滚动。
 */
Ext.tree.Panel.override({
    listeners:{
        afterlayout : function(treePanel, eOpts){
            var emBody = document.getElementById(treePanel.body.id);
            var emView = document.getElementById(treePanel.getView().id);
            var emTable = document.getElementById(treePanel.getView().id).childNodes[0];
            if(emTable != undefined){
                var emTableW = emTable.style.width;
                var newEmTableW = parseInt(emTable.style.width.substr(0,emTableW.length-2))-20;
                emTable.style.width = newEmTableW+"px";
                emTable.style.tableLayout = 'auto';
                emTable.style.borderCollapse = 'separate';
            }
            emView.style.overflow = 'visible';
            if(treePanel.treeGrid != 'Y'){
                emView.style.overflowX = 'auto';
            }else{
                emView.style.overflowX = 'hidden';
            }
            emView.style.overflowY = 'auto';
            emView.style.position = 'relative';
            var emDivArr = emBody.parentNode.getElementsByTagName("div");
               for(var i = 0; i < emDivArr.length; i++){
                   var emDiv = emDivArr[i];
                   if(emDiv.id.indexOf("gridscroller") == 0 && emDiv.className.indexOf("x-scroller-vertical") > 0){
                       /*if(emDiv.parentNode != null){
                           emDiv.parentNode.removeChild(emDiv);
                       }*/
                       emDiv.style.width = "0px";
                       emView.style.width = treePanel.getWidth()+"px";
                       emBody.style.width = treePanel.getWidth()+"px";
                   }
               }
         }
    }
});
  1. 在jsp中或在通用的js文件中加入下面的重写Ext.tree.Panel afterlayout的方法;
  2. 仅在ext4.0.7中简单测试过,其他版本请自行测试。
  3. 若在使用过程中发现会引起其他bug,请在原文出处回复讨论,谢谢。
作者:java小秦
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

转载于:https://www.cnblogs.com/qinjunli/p/5976760.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值