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(); ) { context.Response.Write("nodata"); } else { List<OptionContent> list = new List<OptionContent>(); ; 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); ) { context.Response.Write("nodata"); } else { List<OptionContent> list = new List<OptionContent>(); ; 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对应查看
Asp.Net下,基于Jquery的Ajax二级联动的更多相关文章
- 份-城市,基于jQuery的AJAX二级联动,用Struts2整合AJAX【非数据库版】
package loaderman.provincecity; import java.io.IOException; import java.util.LinkedHashSet; import j ...
- 源码来袭!!!基于jquery的ajax分页插件(demo+源码)
前几天打开自己的博客园主页,无意间发现自己的园龄竟然有4年之久了.可是看自己的博客列表却是空空如也,其实之前也有写过,但是一直没发布(然而好像并没有什么卵用).刚开始学习编程时就接触到博客园,且在博客 ...
- 基于jQuery的ajax对WebApi和OData的封装
基于jQuery的ajax对WebApi和OData的封装 WebApi 的使用带来了一个显著的特点,对type有一定的要求.一般ajax的type无非就是两种,GET和POST.如果用JSONP来跨 ...
- asp.net DropDownList无刷新ajax二级联动实现详细过程
只适合新手制作DropDownList无刷新ajax二级联动效果: 数据库实现,添加两表如图:表1,pingpai,表2,type,具体数据库实现看自己的理解: //页面主要代码: <asp:S ...
- Python Django 之 基于JQUERY的AJAX 登录页面
一.基于Jquery的Ajax的实现 1.url 2.vews 3.templates
- 基于JS的ajax的实现,JSON和JSONP,基于JQuery的ajax的实现
基于JS的ajax的实现,JSON和JSONP,基于JQuery的ajax的实现1.基于JS的ajax的实现 step1: var xmlhttp = XMLHttprequest() #实例化一个对 ...
- Json 基于jQuery+JSON的省市联动效果
helloweba.com 作者:月光光 时间:2012-09-12 21:57 标签: jQuery JSON Ajax 省市联动 省市区联动下拉效果在WEB中应用非常广泛,尤其在一些 ...
- 在asp.net中使JQuery的Ajax用总结
自从有了JQuery,Ajax的使用变的越来越方便了,但是使用中还是会或多或少的出现一些让人短时间内痛苦的问题.本文暂时总结一些在使用JQuery Ajax中应该注意的问题,如有不恰当或者不完善的地方 ...
- 基于jQuery的ajax系列之用FormData实现页面无刷新上传
接着上一篇ajax系列之用jQuery的ajax方法向服务器发出get和post请求写,这篇主要写如何利用ajax和FormData实现页面无刷新的文件上传效果,主要用到了jQuery的ajax()方 ...
随机推荐
- B. An express train to reveries
B. An express train to reveries time limit per test 1 second memory limit per test 256 megabytes inp ...
- Problem P
题意:FJ养牛,他想知道中间的牛是那一头: 思路:这道题有点水,思路就不写了 #include #include #include #define maxn 10005 using namespace ...
- 通用的contain函数
用来检测节点所属关系:document.documentElement.contains(document.body) function contains(refNode, otherNode) {i ...
- HTML学习笔记 w3sCss盒子模型(阴影)(div的一些使用)案例 第十节 (原创) 参考使用表
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Oracle 11g服务器安装详细步骤——图文教程
1.大家可以根据自己的操作系统是多少位(32位或64位)的,到官网下载相应的安装程序,如下图所示. 有一点需要注意,Oracle的安装程序分成2个文件,下载后将2个文件解压到同一目录即可. 2.下载完 ...
- MyBatis学习笔记1--初识MyBatis
我也是初学者,写博客只是想把自己的整个思路整理一下,有不对或者不好的地方,请大家多多指正. 1.MyBatis简介 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射. ...
- 激光相机数据融合(5)--Gazebo仿真数据融合
这一节将用ROS+Gazebo 环境获取激光获取点云,并用PCL和OPENCV处理,源代码在:https://github.com/ZouCheng321/5_laser_camera_sim 由于激 ...
- 重启mysql主从同步mongodb(tungsten-replicator)
1. 连接mysql mysql -uroot -p;(mysql从库) 输入数据库密码 2. 停止主同步 mysql> stop slave; 3. 清数据 将mongo库数据清空 4. 杀主 ...
- 2)C语言的基本知识(C自考学习)
字符集 在C语言程序中允许出现的所有基本字符的组合称为C语言的字符集.C语言的字符集就是ASCII字符集.主要包含一下几类: 1)大小写英文字母A~Z,a~z(52个) 2)数字0-9(10个) 3) ...
- python学习笔记 map&&reduce
---恢复内容开始--- 1.map 1)map其实相当对吧运算符进行一个抽象,返回的是一个对象,但是这里不知道为什么不可以对一个map返回变量打印两次,难道是因为回收了? def f(x): ret ...