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

发表于:2007-06-30来源:作者:点击数: 标签:
在ASP.NET Portal Starter Kit中有在列表框中选择指定项,通过点击上下按钮来实现排序的功能(如下图)。 通常我想到的方法是(以上移为例):获取选中项的排序号和选中项的上一项的排序号,交换它们的排序号即可。排序号的方式,就以1,2,3,4……的形式,


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

通常我想到的方法是(以上移为例):获取选中项的排序号和选中项的上一项的排序号,交换它们的排序号即可。排序号的方式,就以1,2,3,4……的形式,新建的标签的序号在最后一个的基础上加一。在ASP.NET Portal Starter Kit中采取的方式是:通过1,3,5,7……的形式来表示排序号,每一次增删都重新构造排序号。在上移时,将当前的排序号减3,这样新的排序号就在它原来上一位的前面,且在上两位的后面。如:将第7位上移,那么新的顺序是1,3,4,5,9。
代码如下(部分代码,详细的可对照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);
}
更多相关内容:点击这里>>

原文转自:http://www.ltesting.net