zoukankan      html  css  js  c++  java
  • asp.net+jQuery应用JSON实现无刷新三级联动实例(转)

    本文应用到jquery、json、asp.net结合来实现无刷新三级联动效果,使用asp.net实现二级联动、三级联动效果很简单,不过不是无刷新就不爽了,所以收集一个无刷新联动的实现例子。

    三个下拉控件:
    <asp:DropDownList ID="ddl1" runat="server" Width="100px" ></asp:DropDownList>
    <asp:DropDownList ID="ddl2" runat="server" Width="100px" ></asp:DropDownList>
    <asp:DropDownList ID="ddl3" runat="server" Width="100px" ></asp:DropDownList>
    JS代码:

    Code

    <script src="js/jquery-1.4.2.min.js" type="text/javascript" ></script>
    <script type="text/javascript">
        $(document).ready(function () {       
            GetA();
            $("#ddl1").change(function () { GetB(); });         
            $("#ddl2").change(function () { GetC(); });        
        });     
       
        function GetA()
        {
            $("#ddl1").html("");
            $("#ddl1").append("<option value='-1' selected='selected'>请选择...</option>");
            //$("select[name$=ddl1] > option:selected").remove();
            var strId = 0;
            $.getJSON("LoadClass.ashx?ddlId="   strId, function (data) {
             for (var i = 0; i < data.length; i ) {
                 $("select[name$=ddl1]").append($("<option></option>").val(data[i].ID).html(data[i].Cname));
             };
             GetB();         
         });
                    
        }
        function GetB()
        {
            $("#ddl2").html(""); $("#ddl3").html("");
            var strId = $("#ddl1").attr("value");      
            if (strId != 0) {
                $.getJSON("LoadClass.ashx?ddlId="   strId, function (data) {
                    for (var i = 0; i < data.length; i ) {
                        $("select[name$=ddl2]").append($("<option></option>").val(data[i].ID).html(data[i].Cname));
                    };
                    GetC();             
                });                           
            }          
        }
        function GetC()
        {
            $("#ddl3").html("");
            var strId = $("#ddl2").attr("value");
            if (strId != 0) {
                $.getJSON("LoadClass.ashx?ddlId="   strId, function (data) {
                    for (var i = 0; i < data.length; i ) {
                        $("select[name$=ddl3]").append($("<option></option>").val(data[i].ID).html(data[i].Cname));
                    };                       
                });                
            }       
        }
    </script>

    LoadClass.ashx
    Code

    using System;
    using System.Web;

    using System.Text;
    using System.Data;

    public class LoadClass : IHttpHandler {
       
        public void ProcessRequest (HttpContext context) {
            // 数组   [{"ID":"275","Cname":"A1"},{"ID":"319","Cname":"A2"},{"ID":"322","Cname":"A3"}]
            int strId = Convert.ToInt32(context.Request["ddlId"]);              
            string strSQL = "select * from Class where parent_Ptr="   strId   " order by classOrder asc ";
            db d = new db();
            DataTable dt = d.getDT(strSQL);
            StringBuilder strClass = new StringBuilder();
            if (dt != null)
            {
                strClass.Append("[");
                for (int i = 0; i < dt.Rows.Count; i )
                {
                    strClass.Append("{");
                    strClass.Append("\"ID\":\""   dt.Rows[i]["id"].ToString()   "\",");
                    strClass.Append("\"Cname\":\""   dt.Rows[i]["classCname"].ToString()   "\"");

                    if (i != dt.Rows.Count - 1)
                    {
                        strClass.Append("},");
                    }
                }

            }
            strClass.Append("}");
            strClass.Append("]");     
            context.Response.ContentType = "application/json";
            context.Response.ContentEncoding = Encoding.UTF8;
            context.Response.Write(strClass.ToString());
            context.Response.End();
        }

        public bool IsReusable {
            get {
                return false;
            }
        }

    }注意:
    //后台只能获取value值,不能直接获取text,需要通过js、控件中转
    //结果:275 276 277
    Label1.Text = Request.Form[ddl1.UniqueID] + " "                    + Request.Form["ddl2"] + " "                    + Request.Form[ddl3.ClientID.Replace("_", "$")] ;遇到的问题:下拉框text的值通过HiddenField控件中转 <asp:HiddenField ID="HiddenField1" runat="server" />
    <asp:HiddenField ID="HiddenField2" runat="server" />
    <asp:HiddenField ID="HiddenField3" runat="server" />
    把选中下拉框的值赋予隐藏控件中:
    <script type="text/javascript">      
    var Key1 = $("#ddl1>option:selected").val();
    $('#HiddenField1').val(Key1);
    var Key2 = $("#ddl2>option:selected").val();
    $('#HiddenField2').val(Key2);
    var Key3 = $("#ddl3>option:selected").val();
    $('#HiddenField3').val(Key3);   
    </script>
    选择下拉框后 动态赋值到HiddenField 控件中的值 无法与下拉框选中的值相对应

  • 相关阅读:
    数组优化 Dijkstra 最短路
    F
    树 (p155, 从中序和后续回复二叉树)
    矩阵连乘 LRJ白书 p141 栈 解析表达式
    Train Problem II HDU 1023 卡特兰数
    codevs 1166 矩阵取数游戏
    BZOJ 2754: [SCOI2012]喵星球上的点名
    2017.6.11 校内模拟赛
    HDU 2896 病毒侵袭
    UvaLive 4670 Dominating Patterns
  • 原文地址:https://www.cnblogs.com/zhwl/p/1969200.html
Copyright © 2011-2022 走看看