C#實(shí)現(xiàn)無(wú)限級(jí)聯(lián)下拉列表框
本文實(shí)例為大家分享了無(wú)限級(jí)聯(lián)下拉列表框的的實(shí)現(xiàn)方法,具體內(nèi)容如下
可能有一個(gè)樹(shù)型結(jié)構(gòu)的表,它可能有ID,Name,ParentID,Level等字段,下面要實(shí)現(xiàn)的就是從一級(jí)節(jié)點(diǎn)開(kāi)始,一級(jí)一級(jí)的列出來(lái),并以
下拉列表框的形式體現(xiàn)出來(lái),就像是N級(jí)聯(lián)動(dòng)。
效果圖:
兩個(gè)問(wèn)題:
1、建立操作時(shí)的聯(lián)動(dòng),它不需要進(jìn)行自動(dòng)綁定
2、編輯操作時(shí)的聯(lián)運(yùn),它需要根據(jù)子節(jié)點(diǎn),逐級(jí)自己綁定到父節(jié)點(diǎn),直到根
實(shí)現(xiàn):
JS代碼
<script type="text/javascript"> function areaOnSelect(obj) { var res = ''; $.ajax({ url: '@Url.Action("GetSubTree")', type: 'GET', data: { parentId: obj.value }, success: function (msg) { $(obj).nextAll().remove(); res = "<select name='Sub' onchange='areaOnSelect(this)'>"; res += "<option value=''>請(qǐng)選擇</option>"; $.each(msg, function (i, item) { res += "<option value='" + item["ID"] + "'>" + item["Name"] + "</option>"; }); res += "</select>"; if ($(res).find("option").size() > 1) $(obj).after(res); } }); } </script>
C#代碼:
#region 樹(shù)型結(jié)構(gòu)相關(guān) /// <summary> /// 遞歸找老祖宗 /// </summary> /// <param name="father"></param> void GetFather(SubItem father) { if (father != null) { father.Parent = _subList.FirstOrDefault(i => i.ID == father.ParentID); GetFather(father.Parent); } } /// <summary> /// 弟妹找子孫 /// </summary> /// <param name="father">父對(duì)象</param> void getSons(SubItem father) { if (father != null) { father.Sons = _subList.Where(item => item.ParentID.Equals(father.ID)).ToList(); father.Sons.ForEach(item => { item.Parent = father; getSons(item); }); } } #endregion
C#拼接下拉列表框相關(guān):
/// <summary> /// 遞歸得到它的所有祖宗以selectlist的形式進(jìn)行拼接 /// </summary> /// <param name="son"></param> /// <param name="sbr"></param> void getSelectList(SubItem son, StringBuilder sbr) { StringBuilder inSbr = new StringBuilder(); if (son != null) { if (son.ParentID == 0) inSbr.Append("<select name='Parent' onchange = 'areaOnSelect(this)' >"); else inSbr.Append("<select name='Sub'>"); GetCommon_CategoryByLevel(son.Level).ToList().ForEach(i => { if (i.ID == son.ID) inSbr.Append("<option value='" + i.ID + "' selected='true'>" + i.Name + "</option>"); else inSbr.Append("<option value='" + i.ID + "'>" + i.Name + "</option>"); }); inSbr.Append("</select>"); sbr.Insert(0, inSbr); getSelectList(son.Parent, sbr); } }
C#得到同一深度的節(jié)點(diǎn)(同輩節(jié)點(diǎn))相關(guān):
/// <summary> /// 得到指定深度的列表 /// </summary> /// <param name="level"></param> /// <returns></returns> public List<SubItem> GetCommon_CategoryByLevel(int level) { var linq = from data1 in _subList join data2 in _subList on data1.ParentID equals data2.ID into list select new SubItem { ID = data1.ID, Level = data1.Level, Name = data1.Name, Parent = list.FirstOrDefault(), ParentID = data1.ParentID, }; return linq.Where(i => i.Level.Equals(level)).ToList(); }
MVC頁(yè)面action相關(guān):
public ActionResult Category(int? id) { ViewData["Parent"] = new SelectList(_subList.Where(i => i.ID == (id ?? 0)), "ID", "Name", id ?? 1); SubItem current = _subList.FirstOrDefault(i => i.ID == (id ?? 1)); GetFather(current); StringBuilder sbr = new StringBuilder(); getSelectList(current, sbr); ViewData["edit"] = sbr.ToString();//修改時(shí),進(jìn)行綁定 return View(); }
MVC頁(yè)面代碼相關(guān):
@Html.Raw(ViewData["edit"].ToString())
C#樹(shù)型結(jié)構(gòu)實(shí)體類相關(guān):
/// <summary> /// 樹(shù)型分類結(jié)構(gòu) /// </summary> public class Category { /// <summary> /// 父ID /// </summary> public int ParentID { get; set; } /// <summary> /// 樹(shù)ID /// </summary> public int ID { get; set; } /// <summary> /// 樹(shù)名稱 /// </summary> public string Name { get; set; } /// <summary> /// 深度 /// </summary> public int Level { get; set; } /// <summary> /// 子孫節(jié)點(diǎn) /// </summary> public List<Category> Sons { get; set; } /// <summary> /// 父節(jié)點(diǎn) /// </summary> public Category Parent { get; set; } }
好了,現(xiàn)在我們的N級(jí)無(wú)限下拉列表框就做好了,感謝大家的閱讀。
上一篇:C# WCF簡(jiǎn)單入門圖文教程(VS2010版)
欄 目:C#教程
本文標(biāo)題:C#實(shí)現(xiàn)無(wú)限級(jí)聯(lián)下拉列表框
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/6642.html
您可能感興趣的文章
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻 器左下角滾動(dòng)新聞效果的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已安裝軟件變化的方法
- 01-10C#實(shí)現(xiàn)多線程下載文件的方法
- 01-10C#實(shí)現(xiàn)Winform中打開(kāi)網(wǎng)頁(yè)頁(yè)面的方法
- 01-10C#實(shí)現(xiàn)遠(yuǎn)程關(guān)閉計(jì)算機(jī)或重啟計(jì)算機(jī)的方法
- 01-10C#自定義簽名章實(shí)現(xiàn)方法
- 01-10C#文件斷點(diǎn)續(xù)傳實(shí)現(xiàn)方法
- 01-10winform實(shí)現(xiàn)創(chuàng)建最前端窗體的方法


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開(kāi)的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻 器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過(guò)重寫Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-11Mac OSX 打開(kāi)原生自帶讀寫NTFS功能(圖文
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10delphi制作wav文件的方法
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載