jQueryJSON 无刷新三级联动

简介:

曾祥展

 

 曾祥展

 

 

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

<%@ WebHandler Language="C#" Class="LoadClass" %>

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 控件中的值 无法与下拉框选中的值相对应!

可能与初始化有关,赋值这段代码应该放到什么地方呢?或者有什么好的方法,欢迎讨论?



    本文转自曾祥展博客园博客,原文链接:http://www.cnblogs.com/zengxiangzhan/archive/2010/02/21/1670646.html,如需转载请自行联系原作者

相关文章
|
5月前
|
JSON 前端开发 Java
利用Spring Boot处理JSON数据实战(包括jQuery,html,ajax)附源码 超详细
利用Spring Boot处理JSON数据实战(包括jQuery,html,ajax)附源码 超详细
62 0
|
6月前
|
JSON JavaScript 数据格式
jQuery将json性别数据int类型进行格式化渲染
jQuery将json性别数据int类型进行格式化渲染
27 0
|
6月前
|
JSON 数据格式
jQuery+ajax解析json数据渲染
jQuery+ajax解析json数据渲染
31 0
|
7月前
|
XML JSON JavaScript
基于jquery+html开发的json格式校验工具
JSON是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。
36 0
|
11月前
|
XML 存储 JSON
【jquery】前端数据格式:json、xml对比
【jquery】前端数据格式:json、xml对比
95 0
|
JSON 前端开发 JavaScript
jquery ajax 和servlet json 结合的简单小例子
jquery ajax 和servlet json 结合的简单小例子
110 0
|
JSON JavaScript 数据格式
jquery请求json数据失败但是不报错
jquery请求json数据失败但是不报错
139 0
jquery请求json数据失败但是不报错
|
XML JSON JavaScript
jQuery、ajax、JSON三者之间的关系
最近在做项目的过程中,对于jQuery、ajax、JSON这三者的关系总是理不清楚,于是,在简单是使用,有了丁点的经验,于是对这三者的关系做了下研究: 1、jQuery : 以下来自百度百科 jQuery是一个快速、简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架)。
3490 0
|
JavaScript Linux 应用服务中间件
Python全栈 Web(Ajax JSON JQuery)
Flask、Python、Django、框架、服务器、客户端、浏览器、交互、WEB、Python前端、CSS、JAVA、HTML、H5、PHP、JavaScript、JQuery、分布式开发
2970 0
|
JSON 前端开发 .NET
如何构建ASP.NET MVC4&JQuery&AJax&JSon示例
背景:   博客中将构建一个小示例,用于演示在ASP.NET MVC4项目中,如何使用JQuery Ajax。 步骤: 1,添加控制器(HomeController)和动作方法(Index),并为Index动作方法添加视图(Index.cshtml),视图中HTML如下: 输入你的姓名: 输入你的年龄: 提交 清空   视图中包含两个文本框,分别用来输入名字和年龄,包含连个按钮,分别用来提交信息和清空文本框的内容,同时包含一个段落,用来显示Ajax返回的数据信息。
1053 0