extjs 滚动条自动定位

今天客户提了一个需求,滚动条自动定位问题。大致如下:
 树控件菜单中 ,有很多节点,当打开较多的时候,会显示不下,出现滚动条,用户展开一个靠下的节点时候,往往要先拉动滚动条,才能看到展开节点的叶子节点。客户希望在展开节点的时候,滚动条会自动定位,不需要拉动就能看到下面的子节点。
   查找相关代码发现 滚动条是跟随焦点走的,焦点在哪,滚动条默认就向哪滚动,点击父节点或者展开按钮时候,是当前节点获取焦点,故滚动条只会滚动到当前节点处,要想实现用户的需求,最好是当前展开节点的最后一个节点获取焦点,查找ext api 发现treenode无获取焦点的方法,查看其元代吗,发现 treenode 的获取焦点 要通过treenodeui获取,故修改代码如下: //监听树的展开事件,将焦点转移到当前节点的最后一个子节点
    expandnode :function(node){
var curr = node.lastChild ;
if(curr){
curr.getUI().focus();
}
},
// 监听click事件,同样将焦点转移到当前节点的最后子节点
'click':function(node){
if(node.isLeaf()){
openTab(node);
}else{

node.expand(false,true,function(temp){
var curr = temp.lastChild ;
if(curr){
curr.getUI().focus();
}
});
//树展开的时候 ,单击节点,使滚动条自动定位到相应的位置
Ext.getCmp('treeAccordion').doLayout();

}

},

通过上述方法,使树的滚动条自动滚动,系统的易用性得到了增强。

你可能感兴趣的:(web前端)