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

来源:http://www.cnblogs.com/shanshanlaichi/archive/2016/12/31/6238714.html
-Advertisement-
Play Games

恢復內容開始 第一次發表博文,發表博文的目的是鞏固自己的技術,也能夠共用給大家。寫的不好的地方,希望大家多給給意見。老司機勿噴 數據結構() NewsTypeId 新聞ID, NewsTypeName 新聞名稱 NewsTypeParentId 父級ID 後臺語言:ASP.NET MVC4 後臺代碼 ...


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

第一次發表博文,發表博文的目的是鞏固自己的技術,也能夠共用給大家。寫的不好的地方,希望大家多給給意見。老司機勿噴

 

數據結構()

NewsTypeId 新聞ID

NewsTypeName 新聞名稱

NewsTypeParentId 父級ID

 

後臺語言:ASP.NET MVC4

 

後臺代碼:

  /// <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>

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文地址:http://www.cnblogs.com/cocowool/archive/2012/07/05/2578487.html YUM代理設置 編輯/etc/yum.conf,在最後加入 # Proxy proxy=http://username:password@proxy_ip:por... ...
  • 1、Bin 目錄 用來存放編譯的結果,bin是二進位binary的英文縮寫,因為最初C編譯的程式文件都是二進位文件,它有Debug和Release兩個版本,分別對應的文件夾為bin/Debug和bin/Release,這個文件夾是預設的輸出路徑,我們可以通過:項目屬性—>配置屬性—>輸出路徑來修改。 ...
  • 1、在程式最前面加: #define _CRT_SECURE_NO_DEPRECATE 2、在程式最前面加: #pragma warning(disable:4996) 3、把scanf改為scanf_s; 4、無需在程式最前面加那行代碼,只需在新建項目時取消勾選“SDL檢查”即可; 5、若項目已建 ...
  • 一、下麵是在創建一個新的項目是我最常用的,現在對他們一一做一個詳細的介紹: 1、Win32控制台應用程式我平時編寫小的C/C++程式都用它,它應該是用的最多的。 2、名稱和解決方案名稱的區別:名稱是項目的名稱,一個解決方案中可以包含多個項目,所以解決方案名稱包含項目名稱。 3、新建Git存儲庫(G) ...
  • 應用場景 應用場景 angular2(下文中標註位NG2)項目和.net mvc項目分別開發,前期採用跨域訪問進行並行開發,後期只需要將NG2項目的生產版本合併到.net項目。 NG2項目概述 NG2項目概述 ng2項目採用的是angular-cli搭建的框架。 使用type script、rxjs ...
  • 在我上篇隨筆《在DevExpress程式中使用Winform分頁控制項直接錄入數據並保存》中介紹了在GridView以及在其封裝的分頁控制項上做數據的直接錄入的處理,介紹情況下數據的保存和校驗等操作,不過還沒有涉及到數據列表選擇的這種方式,而這種在項目應用也是比較廣泛的一種輸入方式。本篇隨筆繼續探討在G... ...
  • //我的C#是跟著猛哥(劉鐵猛)(算是我的正式老師)《C#語言入門詳解》學習的,微信上猛哥也給我講解了一些不懂得地方,對於我來說簡直是一筆巨額財富,難得良師! 這次與大家一起學習C#中的值參數 傳值參數(也叫值參數) 值參數 (value parameter) 什麼是值參數? 這是從《C#語言規範5 ...
  • 看下組織結構: System.Object System.MarshalByRefObject System.Threading.WaitHandle System.Threading.Mutex System.Threading.Semaphore System.Threading.EventWa ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...