RDIFramework.NET V2.7 Web版本升手风琴+树型目录(2级+)方法

RDIFramework.NET V2.7 Web版本升手风琴+树型目录(2级+)方法

  手风琴风格在Web应用非常的普遍,越来越多的Web应用都是采用这种方式来体现各个功能模块,传统的手风琴风格只支持两级模块,当我们的功能模块多于两级时,我们一般采用树来构造功能菜单(我们的框架也提供了这种方式),但这种方式没有手风琴效果美观,因此我们采用了手风琴+树的形式来构造“手风琴+树型目录(2级+)”界面风格,以展示多级功能菜单,满足用户的要求。Web展示效果如下:

  

  要以“手风琴+树型目录(2级+)”的风格来展示功能模块,我们需要在“系统配置”的“个性化”设置中进行个性化设置,这儿的设置可针对不同人的爱好进行各自的设置。如下图所示:

  

  具体实现方式为以下几个步骤:

 一、设置SysConfig.js,增加一个展示方式,如下图所示: 

 

 二、在newlayout.js中增加一个展现形式的判断,单独判断我们新增的“AccordionTree”展示样式,如下图所示:

 

  其中的AccordionTree.init();代码如下:

//手风琴 + tree
var AccordionTree = {
    init: function () {
        $.each(_menus, function (i, n) {
            var cssIcon = ‘icon icon-application_osx‘; //没有设置图标,则取一个默认图标
            if (n.iconCls) {
                cssIcon = n.iconCls;
            }
            $(‘#wnav‘).append(‘<div style="padding:0px;" title="‘ + n.text
                             + ‘" data-options="border:false,iconCls:\‘‘
                             + cssIcon
                             + ‘\‘"><ul id="nt‘
                             + i
                             + ‘"></ul></div>‘);
        });
        $("#wnav").accordion({
            fit: true,
            border: false,
            onSelect: function (t, i) {
                $(‘#nt‘ + i).tree({
                    lines: false,
                    animate: true,
                    data: _menus[i].children,
                    onClick: function (node) {
                        if (node.attributes.url != "" && node.attributes.url != ‘#‘) {
                            addTab(node.text, node.attributes.url + ‘?navid=‘ + node.id, node.iconCls);
                        } else {
                            $(‘#nt‘ + index).tree(‘toggle‘, node.target);
                        }
                    }
                });
            }
        });
    }
};

 三、修改Default.aspx.cs代码,如下图所示:  

  其中的:GetAccordionTreeJsonByTable代码如下:   

       /// <summary>
        /// 根据DataTable生成AccordionTree Json树结构
        /// </summary>
        /// <param name="tabel">数据源</param>
        /// <param name="idCol">ID列</param>
        /// <param name="txtCol">Text列</param>
        /// <param name="rela">关系字段</param>
        /// <param name="pId">父ID</param>
        /// <returns>返回json数据</returns>
        private string GetAccordionTreeJsonByTable(DataTable tabel, string idCol, string txtCol, string rela, object pId)
        {
            result += tmpStr;
            tmpStr = string.Empty;

            if (tabel.Rows.Count <= 0) return result;
            tmpStr += "[";
            var filer = string.Format("{0}=‘{1}‘", rela, pId);
            var rows = tabel.Select(filer);
            if (rows.Length > 0)
            {
                foreach (var row in from row in rows
                                    let moduleType = BusinessLogic.ConvertToInt(row[PiModuleTable.FieldModuleType])
                                    where moduleType == null || moduleType == 2 || moduleType == 3
                                    select row)
                {
                    tmpStr += "{\"id\":\"" + row[idCol] + "\",\"text\":\"" + row[txtCol]
                              + "\",\"iconCls\":\"" +                              BusinessLogic.ConvertToString(row[PiModuleTable.FieldIconCss]).Replace("icon ", "")
                              + "\",\"attributes\":{"
                              + "\"url\":\"" + row[PiModuleTable.FieldNavigateUrl]
                              + "\",\"FullName\":\"" + row[PiModuleTable.FieldFullName]
                              + "\"}";
                    if (tabel.Select(string.Format("{0}=‘{1}‘", rela, row[idCol])).Length > 0)
                    {
                        tmpStr += RDIFramework.WebCommon.PublicMethod.GetInt(row[PiModuleTable.FieldExpand]) == 1
                            ? ",\"state\":\"open\""
                            : ",\"state\":\"closed\"";
                        tmpStr += ",\"children\":";
                        GetAccordionTreeJsonByTable(tabel, idCol, txtCol, rela, row[idCol]);
                        result += tmpStr;
                        tmpStr = string.Empty;
                    }
                    result += tmpStr;
                    tmpStr = string.Empty;
                    tmpStr += "},";
                }
                tmpStr = tmpStr.Remove(tmpStr.Length - 1, 1);
            } 

            tmpStr += "]";
            result += tmpStr;
            tmpStr = string.Empty;
            return result;

        }

  至此,我们“手风琴+树型目录(2级+)”界面风格整理开发完成。

  附注:在Default.aspx.cs代码中,我们最初的代码已经有一个名为“GetAccordionTreeJsonByTable”的方法,请将其改名为“GetAccordionJsonByTable”,相应的调用它的地方也要同步修改下即可。

作者: EricHu
出处: http://www.cnblogs.com/huyong
微博: 腾讯
Email: [email protected]
QQ 交流:406590790
QQ群:16653241
平台博客: 【CSDN】http://blog.csdn.net/chinahuyong
         【CNBLOGS】http://www.cnblogs.com/huyong
关于作者:高级工程师、信息系统项目管理师、DBA。专注于微软平台项目架构、管理和企业解决方案,多年项目开发与管理经验,曾多次组织并开发多个大型项目,精通DotNet,DB(SqlServer、Oracle等)技术。熟悉Java、Delhpi及Linux操作系统,有扎实的网络知识。在面向对象、面向服务以及数据库领域有一定的造诣。现从事DB管理与开发、WinForm、WCF、WebService、网页数据抓取以及ASP.NET等项目管理、开发、架构等工作。
如有问题或建议,请多多赐教!
本文版权归作者和CNBLOGS博客共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,如有问题,可以通过邮箱或QQ 联系我,非常感谢。

RDIFramework.NET V2.7 Web版本升手风琴+树型目录(2级+)方法

时间: 2024-10-24 12:18:52

RDIFramework.NET V2.7 Web版本升手风琴+树型目录(2级+)方法的相关文章

RDIFramework.NET V2.7 Web版本号升手风琴+树型文件夹(2级+)方法

RDIFramework.NET V2.7 Web版本号升手风琴+树型文件夹(2级+)方法 手风琴风格在Web应用很的普遍,越来越多的Web应用都是採用这样的方式来体现各个功能模块,传统的手风琴风格仅仅支持两级模块,当我们的功能模块多于两级时,我们一般採用树来构造功能菜单(我们的框架也提供了这样的方式),但这样的方式没有手风琴效果美观,因此我们採用了手风琴+树的形式来构造"手风琴+树型文件夹(2级+)"界面风格,以展示多级功能菜单,满足用户的要求.Web展示效果例如以下: 要以&quo

RDIFramework.NET — 基于.NET的快速信息化系统开发框架 — 系列目录

RDIFramework.NET - 基于.NET的快速信息化系统开发框架 - 系列目录 RDIFramework.NET,基于.NET的快速信息化系统开发.整合框架,给用户和开发者最佳的.Net框架部署方案.  框架简单介绍 RDIFramework.NET,基于.NET的快速信息化系统开发.整合框架,为企业或个人在.NET环境下快速开发系统提供了强大的支持,开发人员不需要开发系统的基础功能和公共模块,框架自身提供了强大的函数库和开发包,开发人员只须集中精力专注于业务部分的开发,因此大大提高开

RDIFramework.NET V3.3 Web版新增日程管理功能模块

功能描述 在RDIFramework.NET V3.3 Web版本我们新增了日程管理.基于月.周.日的日历视图,把安排到每一天的具体时间点,让每一天的时间都充分利用:甚至您也可以把个人非工作事项也安排进来,完全是属于自己的全时间管理.就是将每天的工作和事务安排在日期中,并做一个有效的记录,方便管理日常的工作和事务,达到工作备忘的目的.同时也具有对员工日常工作进行指导.监督的作用. 功能展示 日程管理主界面如下图所示: 各视图效果展示 1.日视图 2.月视图 3.周视图 新增日程 新增日程如下图所

RDIFramework.NET V2.9版本 WinFom部分新增与修正的功能

RDIFramework.NET  V2.9版本 WinFom部分新增与修正的功能 转眼间RDIFramework.NET框架走了快6个年头了,随着一个版本一个版本的升级改造,现在已经越来越完美了.使用的客户也越来越多,经受住了大量实战项目的考验! RDIFramework.NET V2.9 WinForm版在2.8的基础上增加与修正了大量功能.包括:对多语言的支持.模块操作权限项设置.增加起始页(对常用功能列表在起始页展示).新增新的字典字典管理界面,提供对“树”类型的数据字典的展示.增加“数

RDIFramework.NET V2.8版本 ━ 开发实例之产品管理(WinForm)

RDIFramework.NET V2.8版本 ━ 开发实例之产品管理(WinForm) 现在,我们使用.NET快速开发整合框架(RDIFramework.NET)来开发一个应用,此应用皆在说明如何使用框架简单快速的进行开发,整合.在这里我们要开发一个产品管理的功能模块,在开发前,我们需要进行数据库的设计,在这儿为了简单说明,我们只涉及到了一张产品表.CASE_PRODUCTINFO(产品信息表) 序号 列 名 数据 类型 长 度 小数 位 标 识 主 键 允许 空 默认值 说 明 1 ID i

RDIFramework.NET V2.9版本多语言的实现

RDIFramework.NET V2.9版本多语言的实现 现在是国际化时代,软件也不能落后.一个公司里很可能会有老外,也可能有台湾的朋友,他们用软件的习惯都不一样,若同样一个软件同时能适应多种语言文化,那是想当的理想了,最起码能比较完善的支持英文版本,大家用起来也会舒服一些. RDIFramework.NET框架中的多语言包,目前是按XML文件的方式进行组织,方便用户自由定义语言包.XML 语言包的好处主要就是客户修改起来容易,直接用记事本就可以修正了,没必要又重新编译源码啥的,非常省事.我们

RDIFramework.NET V2.9版本号 WinFom部分新增与修正的功能

RDIFramework.NET  V2.9版本号 WinFom部分新增与修正的功能 转眼间RDIFramework.NET框架走了快6个年头了,随着一个版本号一个版本号的升级改造,如今已经越来越完美了.使用的客户也越来越多,经受住了大量实战项目的考验! RDIFramework.NET V2.9 WinForm版在2.8的基础上添加与修正了大量功能.包含:对多语言的支持.模块操作权限项设置.添加起始页(对经常使用功能列表在起始页展示).新增新的字典字典管理界面,提供对"树"类型的数据

RDIFramework.NET V3.3 Web框架主界面新增横向菜单功能

功能描述 响应重多客户的要求与心声,RDIFramework.NET框架Web版本主界面新增横向菜单功能.横向菜单更加直观,用户可操作与展示的空间更多,符合实际应用要求. 一.效果展示 最终界面效果: 横向菜单效果图 动画展示效果: 横向菜单动画展示 二.加入方法 1."MenuIndex.cshtml"的文件在项目中的下面位置: 2.修改登录界面代码如下: 登录代码代码修改 3.主界面控制器新增代码如下: 4.修改个性化设置代码,加入横向菜单的设置,如下: 第4步的设置就是在&quo

金笛短信中间件Web版本和研发信息发布

金笛短信中间件VC版经过8年的不断完善,一直在客户中拥有良好的口碑.随着产品用户群日益扩大, 更多客户提出基于WEB收发.管理的需求. 金笛短信中间件Web版从金笛JAVA开发包发展而来,历时V3.1,V3.2,V3.3, V3.4, V3.5各个版本,不觉已经5个春秋. 在这个春日盎然.煦日洋溢的日子里,金笛短信中间件Web版V3.6.1隆重发布了!新版本有更多激动人心的功能.这个版本在推出之前,已经经过长时间的测试与完善,经过多年的技术积累和沉淀,相信这个版本的稳定性和智能化会给您留下印象.