二十四画生的Blog


        ——开始学习Orchard框架
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

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

Posted on 2005-04-18 16:48  二十四画生  阅读(5886)  评论(8编辑  收藏  举报

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);
}


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