Asp.Net下,基于Jquery的Ajax二级联动

最近做一个项目,要求实现二级联动效果。背景为:通过学院的选择,联动出专业选项。起初想直接用微软的控件实现Ajax效果,但是DropDownList控件会自动触发PostBack,在后台根本就不好控制,所以抛弃这种方案,用Jquery实现Ajax效果。直接上代码,简单直观。

1.前端页面(这里给出页面二级联动示意,分别为两个select)

<select name="xsxy" id="xsxy">
    <option>-- 请选择学院名称 --</option>
</select>
<select name="xszy" id="xszy">
    <option>-- 请选择专业名称 --</option>
</select> 

2.所对应Jquery代码

$(function () {
        //ajax加载 注意路径,专业的post参数和学院有所不同,注意
        $.post("../../handler/XyZyHandler.ashx", { "action": "getxydata" }, function (data, status) {
            if (status != "success") {
                $("#xsxy").append("<option>加载学院出错</option>");
            }
            else if (data == "nodata") {
                $("#xsxy").append("<option>暂时没有数据</option>");
            }
            else {
                var options = $.parseJSON(data);
                for (var i = 0; i < options.length; i++) {
                    var option = options[i];
                    $("#xsxy").append("<option value=‘" + option.opvalue + "‘>" + option.optext + "</option>"); //注意这里的option写法
                }
            }
        });

        //当学院改变时,实现专业的联动
        $("#xsxy").change(function () {

            $.post("../../handler/XyZyHandler.ashx", { "action": "getzydata", "xyid": $(this).val() }, function (data, status) {

                if (status != "success") {
                    $("#xszy").append("<option>加载专业出错</option>");
                }
                else if (data == "nodata") {
                    $("#xszy").append("<option>暂时没有数据</option>");
                }
                else {
                    $("#xszy").empty();
                    $("#xszy").append("<option>-- 请选择专业名称 --</option>")
                    var options = $.parseJSON(data);
                    for (var i = 0; i < options.length; i++) {
                        var option = options[i];
                        $("#xszy").append("<option value=‘" + option.opvalue + "‘>" + option.optext + "</option>");
                    }

                }

            });

        });

3.其对应的ashx文件

public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            string action = context.Request["action"];
            Xyzygl xzgl = new Xyzygl();
            //处理学院
            if (action == "getxydata")
            {
                DataTable result = xzgl.Xyzygl_Getxy();   

                if (result.Rows.Count == 0)
                {
                    context.Response.Write("nodata");
                }
                else
                {
                    List<OptionContent> list = new List<OptionContent>();
                    for (int i = 0; i < result.Rows.Count; i++)
                    {
                        string xymc = result.Rows[i]["xymc"].ToString();
                        string xyid = result.Rows[i]["xyid"].ToString();

                        list.Add(new OptionContent() { opvalue = xyid, optext = xymc });

                    }

                    //这里利用json处理更加的灵活,注意在添加数据的时候要以对象的方式,并且以属性的方式表示数据,这样前台在利用数据时就会更简单
                    JavaScriptSerializer jss = new JavaScriptSerializer();
                    context.Response.Write(jss.Serialize(list));

                }
            }
            else if (action == "getzydata")
            {
                string xyid = context.Request["xyid"];
                DataTable result = xzgl.Xyzygl_Getzy(xyid);
                if (result.Rows.Count == 0)
                {
                    context.Response.Write("nodata");
                }
                else
                {
                    List<OptionContent> list = new List<OptionContent>();
                    for (int i = 0; i < result.Rows.Count; i++)
                    {
                        string zymc = result.Rows[i]["zymc"].ToString();
                        string zyid = result.Rows[i]["zyid"].ToString();

                        list.Add(new OptionContent() { opvalue = zyid, optext = zymc });

                    }

                    JavaScriptSerializer jss = new JavaScriptSerializer();
                    context.Response.Write(jss.Serialize(list));
                }
            }

        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }

        public class OptionContent
        {
            public string opvalue { get; set; }
            public string optext { get; set; }
        }
    }

说明:

    1.这里将学院和专业的处理文件写在一个中,通过post的参数进行判断进行相应处理。
    2.将数据结果进行json化,并且将数据结果进行对象的封装,使处理数据时更加的灵活。
    3.对象的创建,直接给出属性,偷了懒,其实可以用参数构建对象,然后给出Set和Get方法。
    4.前台的取值,通过json进行获取,注意看代码。
    5.学院和专业值从数据库中取得,具体细节,这里没有给出,但是读者应该可以了解。
    6.$.post中的参数,最好和ashx对应查看
时间: 2024-10-12 18:12:43

Asp.Net下,基于Jquery的Ajax二级联动的相关文章

份-城市,基于jQuery的AJAX二级联动,用Struts2整合AJAX【非数据库版】

package loaderman.provincecity; import java.io.IOException; import java.util.LinkedHashSet; import java.util.Set; import com.opensymphony.xwork2.ActionSupport; /** * 控制器 * @author AdminTC */ public class ProvinceCityAction extends ActionSupport{ priv

基于jquery的ajax分页插件(demo+源码)

前几天打开自己的博客园主页,无意间发现自己的园龄竟然有4年之久了.可是看自己的博客列表却是空空如也,其实之前也有写过,但是一直没发布(然而好像并没有什么卵用).刚开始学习编程时就接触到博客园,且在博客园学习了很多的知识,看过很多人的分享.说来也惭愧,自己没能为园友们分享自己的所学所得(毕竟水平比较差). 过去的一年也是辗转了几个城市换了几份工作(注定本命年不太平?).八月份来到现在所在的公司(OTA行业),公司是做互联网的,所以可能大家的前端都屌屌的?之前一直从事.NET开发(现在在这边也是),

基于jquery的Ajax实现 文件上传

---------------------------------------------------------------遇到困难的时候,勇敢一点,找同学朋友帮忙,找导师求助. Ajax Ajax简介 AJAX(Asynchronous Javascript And XML)翻译成中文就是"异步Javascript和XML".即使用Javascript语言与服务器进行异步交互,传输的数据为XML(当然,传输的数据不只是XML,现在更多使用json数据). 同步交互:客户端发出一个请

基于jQuery+JSON的省市联动效果

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

Json 基于jQuery+JSON的省市联动效果

helloweba.com 作者:月光光 时间:2012-09-12 21:57 标签: jQuery  JSON  Ajax  省市联动 省市区联动下拉效果在WEB中应用非常广泛,尤其在一些会员信息系统.电商网站最为常见.开发者一般使用Ajax实现无刷新下拉联动.本文将讲述,利用jQuery插件,通过读取JSON数据,实现无刷新动态下拉省市二(三)级联动效果. 查看演示 下载源码 HTML 首先在head中载入jquery库和cityselect插件. <script type="tex

jquery json ajax三级联动

province_city_area.jsp 1 <%@ page language="java" pageEncoding="UTF-8"%> 2 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 3 <html> 4 <head> 5 <script type="text/javascript"

基于jQuery的ajax系列之用FormData实现页面无刷新上传

接着上一篇ajax系列之用jQuery的ajax方法向服务器发出get和post请求写,这篇主要写如何利用ajax和FormData实现页面无刷新的文件上传效果,主要用到了jQuery的ajax()方法和XMLHttpRequest Level 2的FormData接口.关于FormData,大家可以看MDN文档. 1,先看效果图 期望的功能和效果很简单:点击页面中的上传文件表单控件,选择文件后点击"ajax提交",将文件上传至服务器,上传成功后,页面给出一个简单的提示. 2,前端的代

jquery实现select二级联动

jquery实现一个简单的select二级联动菜单,代码如下 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>jQuery 二级联动</title> 6 <style> 7 .city{ 8 display: none;; 9 } 10 .city_first { 11 display: block; 12 }

测开之路一百五十二:基于jquery的ajax实现(load、get、ajax)

ajax除了用原生的js实现之外,也可以使用jquery实现,而且用jquery更方便 看一个简单的示例,保留上一篇的content路由和html,实现上一篇一样的功能,点击获取内容,局部刷新 准备一个页面用于被调用 <h1>这是content.html的h1标签</h1><p style="background: red"> 这是content.html的p标签,红色 <a href="https://www.baidu.com/&