基于jquery ajax实现DropDownList二级联动

这节主要内容是通过AJAX调用页面后台代码方法实现下拉框二级联动效果,实现步骤如下:

1.创建文件Recipe24.aspx,实现后台代码如下:

// 引入命名空间

 代码如下 复制代码

using System.Web.Services;
// 实现下拉框二级联动AJAX请求加载数据方法
    [WebMethod()]
    public static ArrayList GetSubList(string sBuyID)
    {
        ArrayList subList = new ArrayList();

        if (sBuyID == "1")
        {
            subList.Add(new ListItem("文艺", "1"));
            subList.Add(new ListItem("少儿", "2"));
            subList.Add(new ListItem("人文社科", "3"));
            subList.Add(new ListItem("科技", "4"));
        }
        else if (sBuyID == "2")
        {
            subList.Add(new ListItem("手机通讯", "1"));
            subList.Add(new ListItem("手机配件", "2"));
            subList.Add(new ListItem("摄影摄像", "3"));
            subList.Add(new ListItem("数码配件", "4"));
        }

        return subList;
    }

2.实现页面代码(HTML部分)如下:

 代码如下 复制代码
<body>
    <form id="form1" runat="server">
    <div align="center">
        <fieldset style="width: 400px; height: 150px;">
            <table border="0" cellpadding="10" cellspacing="10">
                <tr>
                    <td>
                        <asp:DropDownList ID="buyList" runat="server" Width="120px">
                            <asp:ListItem Value="0" Text="  ---  请选择  ---  "></asp:ListItem>
                            <asp:ListItem Value="1" Text="图书"></asp:ListItem>
                            <asp:ListItem Value="2" Text="手机数码"></asp:ListItem>
                        </asp:DropDownList>
                    </td>
                    <td>
                        <asp:DropDownList ID="subList" runat="server" Width="120px">
                            <asp:ListItem Value="0" Text="  ---  请选择  ---  "></asp:ListItem>
                        </asp:DropDownList>
                    </td>
                </tr>
            </table>
        </fieldset>
    </div>
    </form>
</body>

3.实现脚本代码如下:

 代码如下 复制代码

<script type="text/javascript">
        $(function () {
            $("#buyList").bind("keyup change", function (e) {
                e.preventDefault();
                // 首先初始化
                $("#subList").empty().append($("<option></option>").val("0").html("  ---  请选择  ---  "));
                if ($(this).val() != "0") {
                    sendData($(this).val());
                }
            });

            function sendData(sBuyID) {
                var loc = window.location.href;
                $.ajax({
                    type: "POST",
                    url: loc + "/GetSubList", // 调动后台页面方法
                    data: '{"sBuyID":"' + sBuyID + '"}',
                    contentType: "application/json; charset=utf-8",
                    dataType: "json",
                    success: function (msg) {
                        // msg.d是数组,由后台数组ArrayList返回,因此可以遍历每个元素
                        $.each(msg.d, function () {
                            // this.Value和this.Text是后台返回数组ArrayList类型包含元素ListItem类型的属性
                            $("#subList").append($("<option></option").val(this.Value).html(this.Text));
                        });
                    },
                    error: function () {
                        alert("ajax请求发生错误");
                    }
                });
            }
        });
    </script>

4.下拉框二级联动效果图:

5.分析XmlHttpRequest对象,可看到请求响应的数据msg.d的结构如下(通过下图就知道msg.d的每个元素为什么会有Text和Value属性了):

 

 

时间: 2024-10-27 11:38:01

基于jquery ajax实现DropDownList二级联动的相关文章

jquery ajax 实现城市二级联动下拉效果

jquery代码  代码如下 复制代码 $(document).ready(function(){    $("#house_city").change(function(){      var val=$(this).val();  $.post("/ajax/city_ajax",{id:val},function(data){  $("#house_area").html(data);    }) }); html代码    代码如下 复制

jquery+json实现数据二级联动的方法_jquery

本文实例讲述了jquery+json实现数据二级联动的方法.分享给大家供大家参考,具体如下: function GetCityInfo1() { $("#ddlCITY1").empty(); //$("#ddlCOUNTY").empty(); var strId = $("#ddlPROVINCE1").attr("value"); $('#HiddenPro').val(strId); $.get("../as

基于jQuery Ajax实现上传文件_jquery

本文实例为大家分享了基于jQuery Ajax实现上传文件的关键代码,供大家参考,具体内容如下 JS代码: //保存 function btnAdd() { var formData = new FormData($("#frm")[0]); $.ajax({ url: "/Admin/ContentManage/SaveEdit", type: "POST", data: formData, contentType: false, //必须fa

Ajax实现城市二级联动(三)

本文实例为大家分享了Ajax实现城市二级联动的具体代码,供大家参考,具体内容如下 这是Ajax实现城市二级联动系列文章第三篇,把之前2篇整合在一起 1.html <select id="province"> <option>请选择</option> </select> <select id="city"> <option>请选择</option> </select> 2.

Ajax实现城市二级联动(二)

上一篇联动一种只是城市用ajax请求获取并渲染,这里将省份也用ajax请求并渲染 1.HTML <select id="province"> <option>请选择</option> </select> <select id="city"> <option>请选择</option> </select> 2.JS /* * 省份信息和城市信息全部来源于服务器端 * * 第一

基于jquery ajax 用户无刷新登录方法详解_jquery

Ajax框架就是提供模块化实现Ajax功能的集合,Ajax框架可以是各种语言实现的(比如SAJAX有各种语言的实现),Ajax只是jquery中的一部分, 实例1 复制代码 代码如下: $.ajax({ type:'post',//可选get url:'action.php',//这里是接收数据的PHP程序 data:'data='dsa',//传给PHP的数据,多个参数用&连接 dataType:'text',//服务器返回的数据类型 可选XML ,Json jsonp script html

基于javascript实现全国省市二级联动下拉选择菜单_javascript技巧

本文实例讲述了js实现全国省市二级联动下拉选择菜单,分享给大家供大家参考.具体如下: 效果图:   具体代码: <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>无标题文档</title> <script type="text/javascript"

基于jquery ajax 用户无刷新登录详解介绍

Ajax框架就是提供模块化实现Ajax功能的集合,Ajax框架可以是各种语言实现的(比如SAJAX有各种语言的实现),Ajax只是jquery中的一部分, 实例1  代码如下 复制代码 $.ajax({ type:'post',//可选get url:'action.php',//这里是接收数据的PHP程序 data:'data='dsa',//传给PHP的数据,多个参数用&连接 dataType:'text',//服务器返回的数据类型 可选XML ,Json jsonp script html

基于Jquery+Ajax+Json的高效分页实现代码_jquery

如果说您没用过这些东东的话,我相信看完这篇博文会对您有帮助的,,如果有任何问题不懂或者有bug没问题,欢迎随时联系我, 同时也欢迎高手多给点意见,我不建议在喷子中成长. 本人QQ:364175837 前言 相信很多朋友都用过,Jquery的分页插件,我之前就用的jquery.paper这个,如果有兴趣可以留下QQ,我发份简单的实例源码给您. 该代码是晚上匆忙中完成的,所以没怎么优化,但是主要作为实例来结合这些知识的一个综合运用.好了废话不多说,直接上代码. vs2010+sql2005expre