ExtJS中的accordion布局如何展开特定的item

页面导航:首页 > 网络编程 > JavaScript > ExtJS中的accordion布局如何展开特定的item

ExtJS中的accordion布局如何展开特定的item

来源: 作者: 时间:2016-01-23 10:23 【

因为项目需要,使用了extJS作为后台管理系统的前端框架。 众所周知,后台管理系统一般是根据权限来展示菜单的。 菜单使用了panel的accordion布局,然后内部使用panel包裹了一棵树(treepa

因为项目需要,使用了extJS作为后台管理的前端框架。
众所周知,后台管理系统一般是根据权限来展示菜单的。
菜单使用了panel的accordion布局,然后内部使用panel包裹了一棵树(treepanel)。
刷新时自然是不方便啦,因为想要自动打开上次的菜单展开状态。
关键点如下:
1. 使用Cookies或者HTML5的LocalStorage记住最后展开菜单的rootID。
2. 调用accordion布局中子元素panel的expand()方法即可。
Controller中的部分代码如下:

//根据权限加载菜单
loadMenuResources : function (view) {
    //从store 里用ajax 获取数据
    var _self = this;
    //
    var last_menu_index = 0;
    //创建树
    var tree = _self.createTree(ESSM.resoures);
    //添加菜单
    var menuArray = [];
    Ext.Array.each(tree,function(root,index){
        //
        if(root.id){
            var last_menu_id = getCookie("last_menu_id");
            if(root.id == last_menu_id){
                last_menu_index = index;
            }
        }
        //
        menuArray.push({
            title : root['text'],
            autoScroll : true,
            items : {
                xtype : 'treepanel',
                rootVisible : false,
                lines : false,
                border : false,
                autoScroll : 'none',
                store : _self.createTreeStore(root),
                listeners : {
                    itemclick : function(view,record,item,index,e,eOpts){   //选择菜单事件
                        //创建 controller 显示当前内容
                        _self.createController(_self,record.get('id'),record.get('text'),record);
                        // 如果不出错,缓存 root.id
                        setCookie("last_menu_id", root.id);
                    }
                }
            }
        });
    });
    view.add(menuArray);
    //
    expandLastMenu();
    function expandLastMenu(){
        // 展开最后加载的menu
        //var last_menu_id = getCookie("last_menu_id");
        // fireEvent
        // expand
        try{
            (view.items.items[last_menu_index].expand());
        } catch(ex){
            // 吃掉
        }
    };
}

当然,代码写得有点丑啦。关键是其中的expandLastMenu()方法,其实逻辑很简单,eapand()即可,也没去扒一下EXT的源代码。
此外,两个工具方法(读取和写入Cookie)如下所示:

/****************************************************
 *
 *          cookie相关的函数
 *
 ****************************************************/

// 获取cookie值(key)
function getCookie(cookieName){
    //获取cookie字符串
    var strCookie=document.cookie;
    //将多cookie切割为多个名/值对
    var arrCookie=strCookie.split("; ");
    var cookieValue = null;
    //遍历cookie数组,处理每个cookie对
    for(var i=0;i
Tags:

文章评论

最 近 更 新
热 点 排 行
Js与CSS工具
代码转换工具

<