一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

JQuery 構建客戶/服務分離的鏈接模型中Table中的排序分析

但在這個模型中,由于不能利用這些控件,我們需要借助純Javascript和html靜態代碼來實現,感覺好像挺麻煩的?其實呢......
分頁代碼既然由Webservice接口服務端中間層處理好回傳回來,那么我們的排序代碼也可以這樣的,只是在回傳前進行排序就ok了,下面就分析一下。
  看過上篇的文章,可以知道在Webservice接口服務端中間層處理數據是操縱泛型的List對象
代碼
復制代碼 代碼如下:
List<TB_WEB_NZ_INVESTMENT> list = new List<TB_WEB_NZ_INVESTMENT>();
list = objBusinessFacade.GetTB_WEB_NZ_INVESTMENT_CollectionByFlowID(FlowID);
return new JavaScriptSerializer().Serialize(list);

那么我們的排序代碼就嵌在 藍色行 和 紅色行 之間。
如何排序呢?List這個對象里面有個Sort()方法

顯然我們不能使用默認比較器來進行排序,因為如果這樣就達不到目的(我們需要在頁面點擊某列就按該列進行排序,而默認比較器就達不到這種精準的控制),注:這里并未采用在數據庫上進行排序,為什么?因為通過List泛型對象可以處理的事情就沒必要又要通過數據庫來解決。
List.Sort (泛型 IComparer)
IComparer 是接口由 System.Collections.Generic.List.Sort 和 System.Collections.Generic.List.BinarySearch 方法使用。它提供一種自定義集合排序順序的方法。
該接口有一個需要重載的方法 int Compare(a,b)
通過調整參數a,b的順序實現升序和降序排列
復制代碼 代碼如下:
public int Compare(obj x , obj y)
{
//如果比較的列所對應的表字段的數據類型是DateTime,不同的數據類型對應不同的
return DateTime.Compare(x,y); -- 升序
//return DateTime.Compare(y,x); -- 降序
}

開始構建中間層比較器對象
代碼
復制代碼 代碼如下:
/// <summary>
/// 對象【出資人】比較器
/// </summary>
public class ContributivePerson_INV_Comparer : IComparer<TB_WEB_NZ_INVESTMENT>
{
private ESortType m_ESortType = ESortType.ASC;
public ContributivePerson_INV_Comparer(ESortType eSortType)
{
m_ESortType = eSortType;
}
public int Compare(TB_WEB_NZ_INVESTMENT x, TB_WEB_NZ_INVESTMENT y)
{
int rtnCompare = 0; ;
switch (m_ESortType)
{
case ESortType.ASC:
rtnCompare = string.Compare(x.INV, y.INV);
break;
case ESortType.DESC:
rtnCompare = string.Compare(y.INV, x.INV);
break;
}//switch
return rtnCompare;
}
}//class
/// <summary>
/// 【余額繳付期限】比較器
/// </summary>
public class ContributivePerson_BALDEPER_Comparer : IComparer<TB_WEB_NZ_INVESTMENT>
{
private ESortType m_ESortType = ESortType.ASC;
public ContributivePerson_BALDEPER_Comparer(ESortType eSortType)
{
m_ESortType = eSortType;
}
public int Compare(TB_WEB_NZ_INVESTMENT x, TB_WEB_NZ_INVESTMENT y)
{
int rtnCompare = 0; ;
DateTime xDateTime = DateTime.Parse(x.BALDEPER.ToString());
DateTime yDateTime = DateTime.Parse(y.BALDEPER.ToString());
switch (m_ESortType)
{
case ESortType.ASC:
rtnCompare = DateTime.Compare(xDateTime, yDateTime);
break;
case ESortType.DESC:
rtnCompare = DateTime.Compare(yDateTime, xDateTime);
break;
}//switch
return rtnCompare;
}
}//class

從以上代碼中,我們構造了兩個比較器,分別是【出資人】,【余額繳付期限】
我們構造一個工廠方法,來方便調用
代碼
復制代碼 代碼如下:
/// <summary>
/// 對象排序比較器工廠
/// </summary>
public class ContributivePerson_SortComparerFactory
{
/// <summary>
///
/// </summary>
/// <param name="FieldName"></param>
/// <returns></returns>
public IComparer<TB_WEB_NZ_INVESTMENT> GetSortComparer(string FieldName, ESortType eSortType)
{
IComparer<TB_WEB_NZ_INVESTMENT> IComparer = null;
switch (FieldName)
{
case "BALDEPER"://余額繳付期限
IComparer = new ContributivePerson_BALDEPER_Comparer(eSortType);
break;
case "INV"://投資人
IComparer = new ContributivePerson_INV_Comparer(eSortType);
break;
}//switch
return IComparer;
}
}//class

下面我們進行運用,這個方法是一個Webservice接口端的新寫的方法,我們看見紅色代碼段是排序塊,綠色注解是過濾代碼塊(代碼已經略去)
代碼
復制代碼 代碼如下:
/// <summary>
/// 分頁功能的表格填充服務端(帶排序)
/// </summary>
/// <param name="FlowID"></param>
/// <param name="PageCount">每頁數目</param>
/// <param name="CurrentPage">當前頁</param>
/// <param name="SortType">排序類型:"ASC" ,"DESC"</param>
/// <returns></returns>
[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public string Load_ContributivePerson_Table_Sort(string FlowID, int PageCount,
int CurrentPage, string SortType, string SortFieldName)
{
List<TB_WEB_NZ_INVESTMENT> list = new List<TB_WEB_NZ_INVESTMENT>();
list = objBusinessFacade.GetTB_WEB_NZ_INVESTMENT_CollectionByFlowID(FlowID);
ContributivePerson_SortComparerFactory objFactory = new ContributivePerson_SortComparerFactory();
IComparer<TB_WEB_NZ_INVESTMENT> objSort = null;
if (SortType.ToUpper().Trim() == "ASC")
{
objSort = objFactory.GetSortComparer(SortFieldName,ESortType.ASC);
}
else if (SortType.ToUpper().Trim() == "DESC")
{
objSort = objFactory.GetSortComparer(SortFieldName, ESortType.DESC);
}
list.Sort(objSort);
//部分代碼略去,略去代碼可參看上篇文章
return new JavaScriptSerializer().Serialize(list);
}

通過添加比較器,我們達到了在泛型list對象上的隨心所欲的排序,而不需要通過SQL語句進行排序。在客戶端的頁面只要添加必要的參數就可以實現了,中間層服務端已經實現了全部的核心,客戶端代碼只需要判別是哪個列要進行排序,同時注意【首頁】【】等按排序的順序翻頁即可,這里客戶端的代碼略去
效果圖:
按【余額繳付期限】列進行升序排列

 

按【投資人】降序排列

JavaScript技術JQuery 構建客戶/服務分離的鏈接模型中Table中的排序分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久精品国产亚洲婷婷 | 国产第一页久久亚洲欧美国产 | 亚洲香蕉伊综合在人在线 | 欧美另类videosbestsex | 国产美女在线精品亚洲二区 | 一区二区三区鲁丝不卡麻豆 | 亚洲福利一区福利三区 | 久久国产乱子伦免费精品 | 午夜大片免费完整在线看 | 伊人狼人视频 | 一二三四视频在线社区7 | 激情美女网站 | 亚洲欧洲国产成人精品 | 久久精品视频一区 | 亚洲欧美视频在线播放 | 中日韩一线二线 | 69国产成人综合久久精品91 | 婷婷免费视频 | 一区二区三区高清在线 | 91系列在线观看 | 1区2区3区集团有限公司 | 亚洲国产一区二区三区最新 | 国产三级自拍视频 | 久久99国产精品久久99软件 | 久久婷婷综合中文字幕 | 精品一区二区影院在线 | 免费播放一区二区三区 | 韩国一大片a毛片 | 国产97色在线中文 | 精品福利一区二区免费视频 | 国产在线播放免费 | 国产在线播放免费 | 亚洲免费一级片 | 色老板在线看 | 五月天天堂网 | 亚洲欧美日韩不卡 | 日韩精品一区二区三区视频网 | xfplay影音先锋永久资源 | 激情网页| 国产99视频精品免费视频免里 | 91视频中文 |