现在的位置: 首页 > 综合 > 正文

从ASP.NET Portal Starter Kit中学到的调整顺序新思路

2013年07月13日 ⁄ 综合 ⁄ 共 2573字 ⁄ 字号 评论关闭

ASP.NET Portal Starter Kit中有在列表框中选择指定项,通过点击上下按钮来实现排序的功能(如下图)。

   

通常我想到的方法是(以:上移为例):获取选中项的排序号和选中项的上一项的排序号,交换它们的排序号即可。排序号的方式,就以1234……的形式,新建的标签的序号在最后一个的基础上加一。在ASP.NET Portal Starter Kit中采取的方式是:通过1357……的形式来表示排序号,每一次增删都重新构造排序号。在上移时,将当前的排序号减3,这样新的排序号就在它原来上一位的前面,且在上两位的后面。如:将第7位上移,那么新的顺序是13459

代码如下(部分代码,详细的可对照Tabs.ascx.cs中的代码看):

//上移下移代码

if (tabList.SelectedIndex != -1

{

    
int delta;

    
//因为标签排序号是1,3,5,7,9方式排列的

    
//将一个标签的上移或下移一位,就把标签序号加减3,正好为一偶数就在前后一位的前面或后面。

    
//如:将第7位上移,那么新的顺序是1,3,4,5,9

    if (cmd == "down"

    
{

        delta 
= 3;

    }


    
else 

    
{

        delta 
= -3;

    }


    TabItem t;

    t 
= (TabItem) portalTabs[tabList.SelectedIndex];

    t.TabOrder 
+= delta; 

    
// 重新排序构造新的排序号

    OrderTabs();

}



/// <summary>

/// 将portalTabs中的标签排序

/// </summary>


private void OrderTabs () 

{

    
int i = 1;

    
// 使用指定的比较器对部分 System.Collections.ArrayList 中的元素进行排序。

    
// portalTabs中的对象是TabItem,TabItem对象继承了IComparable接口,实现了以TabOrder的CompareTo

    portalTabs.Sort();

    
// renumber the order and save to database

    
// 将排序后的信息存入XML

    foreach (TabItem t in portalTabs) 

    
{

        
// 将标签的排序号按1, 3, 5,递增的顺序排列

        t.TabOrder = i;

        i 
+= 2;

        
// 将新的排序号写入用户配置文件

        Configuration config = new Configuration();

        config.UpdateTabOrder(t.TabId, t.TabOrder);

    }


}

 

这种方法其实我觉得并不好,只能算是一个新的思路。在OrderTabs()时每次都要循环更新用户配置文件,我觉的还不如,交换序号后在更新用户配置文件。但是用交换序号的方式,要判断是否选中项为第一项(不能上移)或是最后一项(不能下移)。而且程序中还有要将管理项作为最后一项的要求,用交换序号的方式可能又要多写不少代码。可能还有其他的好处我没有想到,所以权衡利弊还是用他的方法吧!

顺便说一个Bug,好像默认提供的程序不能实现上移下移的功能,不知大家遇到了没有。要将Configuration.cs文件中SaveSiteSettings()的方法修改一下才行,修改后的代码:

public void SaveSiteSettings()

{

    
// 原来的:从Cache中获取站点设置信息数据集(好像是个Bug,因为每次更新数据是更新的HttpContext.Current.Items中的)

    
//SiteConfiguration siteSettings = (SiteConfiguration) HttpContext.Current.Cache["SiteSettings"];

    
// 修改后的

    SiteConfiguration siteSettings = (SiteConfiguration) HttpContext.Current.Items["SiteSettings"];


    
// 如果Cache中没有,则重新构建

    if(siteSettings == null)

    
{

        
// If SaveSiteSettings() is called once, the cache is cleared.  If it is

        
// then called again before Global.Application_BeginRequest is called, 

        
// which reloads the cache, the siteSettings object will be Null 

        
// (这一句不知翻译的对不对,好像很重要)如果SaveSiteSettings()被调用过一次后,Cache就回被清除。如果它再一次被调用在Global.Application_BeginRequest前siteSettings为null则重新写Cache

        siteSettings = GetSiteSettings();

    }


    
string configFile = HttpContext.Current.Server.MapPath(ConfigurationSettings.AppSettings["configFile"]);


    
// Object is evicted from the Cache here.  

    
// 将变更后的数据集写入到Xml文件

    siteSettings.WriteXml(configFile);

}


更多相关内容:点击这里>>

抱歉!评论已关闭.