在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);
}
更多相关内容:点击这里>>