Linq語(yǔ)句問(wèn)題的解決方法
學(xué)習(xí)Linq時(shí),經(jīng)常會(huì)遇到Linq語(yǔ)句問(wèn)題,這里將介紹Linq語(yǔ)句問(wèn)題的解決方法。
Navigation 類(lèi)提供取得指定 Url 權(quán)限的功能,使用基本的Linq語(yǔ)句:
- public static int GetPermission(string Url)
 - {
 - var item = Links.Where(p => p.Url == Url).ToList();
 - if (item.Count > 0)
 - {
 - return item[0].Permission;
 - }
 - return 0;
 - }
 
因?yàn)椋谏?html 的時(shí)候,考慮了如果按照相應(yīng)的權(quán)限,一個(gè)分類(lèi)下沒(méi)有任何項(xiàng)目,則不顯示這個(gè)分類(lèi),所以,取 Index 要復(fù)雜一些,要根據(jù)相應(yīng)的權(quán)限進(jìn)行分組,所以相應(yīng)的Linq語(yǔ)句也復(fù)雜一些,使用了 group by:
- public static int GetIndex(string Url, int Permission)
 - {
 - int id = FindCategoryId(Url);
 - var item = from p in Links where (p.Permission & Permission) ==
 
Permission && p.Category_Id != 0- group p by p.Category_Id into g select new { Category_Id = g.Key };
 - var i = item.ToList().FindIndex(p => p.Category_Id == id);
 - return i < 0 ? 0 : i;
 - }
 - public static int FindCategoryId(string Url)
 - {
 - var item = Links.Where(p => p.Url == Url).ToList();
 - if (item.Count > 0)
 - {
 - return item[0].Category_Id;
 - }
 - return 0;
 - }
 
雖然我現(xiàn)在使用的是內(nèi)存里的數(shù)據(jù),不過(guò),因?yàn)楦袷绞呛軜?biāo)準(zhǔn)的數(shù)據(jù)庫(kù)格式,所以,要把這個(gè)配置項(xiàng)放入數(shù)據(jù)庫(kù)表里,或者序列化成 XML,也都是非常方便的 —— 雖然我認(rèn)為這個(gè)必要性不高。
從實(shí)現(xiàn)來(lái)看,這個(gè)方法的速度應(yīng)該不會(huì)很快,不過(guò),因?yàn)閿?shù)據(jù)量小,而且對(duì)于頁(yè)面來(lái)說(shuō),這些在內(nèi)存里做的手腳只能算小Case,所以沒(méi)有明顯感覺(jué)速度上有任何差異。
不過(guò),目前對(duì)于這個(gè)方案,還有一些不滿(mǎn)意,比如,Hide 參數(shù)考慮改成和 Permission 相似,則可以控制每一項(xiàng)在不同權(quán)限下的顯示,比單純的全局 Hide 要靈活得多。再比如,目前沒(méi)有判斷是否會(huì)出現(xiàn)兩條分割線(xiàn)等等。
另外一種實(shí)現(xiàn)方案是,把數(shù)據(jù)的定義放在每一個(gè)頁(yè)面里,這樣的話(huà),雖然設(shè)置分散到了每一個(gè)頁(yè)面,但是卻更符合實(shí)際情況,而且,頁(yè)面 Url 也可以通過(guò)反射得到,刪除頁(yè)面或者頁(yè)面改名都更簡(jiǎn)單,也許是更好的解決方案吧。以上介紹Linq語(yǔ)句。
【編輯推薦】















 
 
 


 
 
 
 