ASP.NET MVC關於Ajax以及Jquery的無限級聯動

---恢復內容開始---ajax

第一次發表博文,發表博文的目的是鞏固本身的技術,也可以共享給你們。寫的很差的地方,但願你們多給給意見。老司機勿噴數據結構

 

數據結構()app

NewsTypeId 新聞ID佈局

NewsTypeName 新聞名稱ui

NewsTypeParentId 父級ID url

 

後臺語言:ASP.NET MVC4spa

 

後臺代碼:orm

  /// <summary>索引

        /// JSON格式的List集合事件

        /// </summary>

        /// <returns></returns>

        public JsonResult FnNewsTypeList()

        {

            int NewsTypeParentId = -1;

            if (!string.IsNullOrEmpty(Request["NewsTypeParentId"]))

            {

                NewsTypeParentId = Convert.ToInt32(Request["NewsTypeParentId"]);

            }

            Maticsoft.BLL.NewsType NTbll = new Maticsoft.BLL.NewsType();

            StringBuilder strWhere = new StringBuilder();

            if (NewsTypeParentId != -1)

            {

                strWhere.AppendLine(" AND NewsTypeParentId ='" + NewsTypeParentId+"'");

            }

            List<Maticsoft.Model.NewsType> NTList = NTbll.NewsTypeList(strWhere.ToString());

            return Json(NTList);

        }

 

 

頁面佈局:

 <div class="form-group ">

     <label class="col-sm-3 control-label">所屬類型:</label>

     <div class="col-sm-8" id="cat">

         <select id="NewsTypeParentId_0" onchange="FirstChange(0)" name="NewsTypeParentId" class="form-control" aria-describedby="firstname-error" aria-invalid="true">

             <option value="0">請選擇</option>

             <option value="1">1</option>

         </select>

     </div>

 </div>

 

 

Jquery語言:

Jquery代碼:

//頁面第一次加載時,將父級爲最高級的類型讀取出來

<script>

 $(function () {

            $.ajax({

                type: "POST",

                url: "/NewsType/FnNewsTypeList",

                data: {

                    NewsTypeParentId: 0

                },

                dataType: "JSON",

                success: function (data) {

                    var SelectArray = new Array();

                    SelectArray.push("<option value=\"0\">請選擇</option>")

                    for (var i = 0; i < data.length; i++) {

//使用Array拼接Html頁面

                        SelectArray.push("<option value=\"");

                        SelectArray.push(data[i].NewsTypeId);

                        SelectArray.push("\">");

                        SelectArray.push(data[i].NewsTypeName);

                        SelectArray.push("</option>");

                    }

//尋找最高級分類追加數據

                    var SelectDom = $("[name=NewsTypeParentId]:eq(0)")

                    SelectDom.find("option").remove()

//Array 的 join 方法,將全部的Html內容鏈接

                    SelectDom.append(SelectArray.join(""))

                }

            })

           

        })

 

 

//下拉框發生改變觸發的時間

ThisId 是當前所屬Select的Id屬性

ChildId 是當前Select的下一級的Select 的ID屬性

 

FirstChange是當下拉框改變時執行的第一個事件

 function FirstChange(ThisId) {

            var ChildId= parseInt(ThisId) + 1;

            SecondChange(ThisId, ChildId)

        }

 

//SecondChange 是尋找被點擊Select下的全部下N級Select,若是存在,則先移除全部下級Select

 

        function SecondChange(ThisId, ChildId) {

            $("#NewsTypeParentId_" + ThisId)

            var ParentVal = $("#NewsTypeParentId_" + ThisId).val();

            //while循環判斷下一個select 是否存在,如存在則刪除直到不存在爲止

            doChildId= ChildId;

            do {

                if ($("#NewsTypeParentId_" + doChildId).length > 0) {

                    $("#NewsTypeParentId_" + doChildId).remove();

                    doChildId++;

                } else {

                    break;

                }

            } while (1)

            if (ParentVal != '') {

//當被點擊的Select值存在時,這時已將其下屬的全部Select清楚,從新調用數據進行生成

                NewsTypeParentId(ParentVal, ChildId);

            }

        }

//Ajax讀取數據進行追加生成

        function NewsTypeParentId(ParentVal, ChildId) {

            if (ParentVal != 0) {

                $.ajax({

                    type: "POST",

                    url: "/NewsType/FnNewsTypeList",

                    data: {

                        NewsTypeParentId: ParentVal

                    },

                    dataType: "JSON",

                    success: function (data) {

//返回值data是JSON格式,當data存在數據時,表示存在下級,進行數據處理和Html生成

//Select的ID屬性值爲NewsTypeParentId_?  從第一級開始,依次爲0,1,2,3,4...

                        if (data.length > 0) {

                            var SelectArray = new Array();

                            SelectArray.push("");

                            SelectArray.push("<select id=\"NewsTypeParentId_");

                            SelectArray.push(ChildId);

                            SelectArray.push("\" onchange=\"FirstChange(");

                            SelectArray.push(ChildId);

                            SelectArray.push(")\" name=\"NewsTypeParentId\" class=\"form-control\" ");

                            SelectArray.push("aria-describedby=\"firstname-error\" aria-invalid=\"true\">");

                            SelectArray.push("<option value=\"0\">請選擇</option> ")

                            for (var i = 0; i < data.length; i++) {

                                SelectArray.push("<option value=\"");

                                SelectArray.push(data[i].NewsTypeId);

                                SelectArray.push("\">");

                                SelectArray.push(data[i].NewsTypeName);

                                SelectArray.push("</option> ");

                            }

                            SelectArray.push("</select>");

//最後將此Select追加至DIV末端

                            $("#cat").append(SelectArray.join(""))

                        }

                    }

                })

            }

        }

 

 

 

Jquery最後傳參數添加數據時,作某些數據處理

//ParentVal是最後一級Select的值,當未選中任何項時,則選擇上一級數據

 var ParentVal = $("[name=NewsTypeParentId]:last").val();

                if (ParentVal == 0) {

//尋找最後一個Select的索引

//將索引-1

                    var SelectIndex = $("[name=NewsTypeParentId]:last").index();

                    SelectIndex = SelectIndex - 1;

                    ParentVal = $("[name=NewsTypeParentId]:eq(" + SelectIndex + ")").val();

                }

</script>

---恢復內容結束---

相關文章
相關標籤/搜索