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()方 ...
随机推荐
- RobotFrameWork安装笔记
1. RobotFrameWork安装配置笔记 1.1. 安装环境 64位win10家庭中文版 网上很多这方面的教程,但是比较零散,这里是自己安装配置的一个简单的笔记. 1.2. 安装说明 由于R ...
- css3+div画大风车
今天已经礼拜三了,周天小颖家的佩佩就要结婚啦,小颖要去当伴娘了,哈哈哈哈哈哈,想想都觉得乐开了花,不过之前她给我说让我当她伴娘时,我说我要减肥,不然她那么瘦弱,我站旁边就感觉像一个圆滚滚的小皮球,小颖 ...
- ES6新特性之Symbol使用细节
在迭代器章节的时候出现过[Symbol.iterator ]的属性,那么到底Symbo到底是什么? 答:Symbol是ES6新定义的一种值,它既不是字符串,也不是对象,而是为javaScript增加的 ...
- IdentityServer4 实现 OAuth 2.0(密码模式 - HTTP Post 方式)
之前写了一篇文章:<IdentityServer4 实现 OpenID Connect 和 OAuth 2.0> 上面这篇文章虽然详细,但都是点到为止的介绍,并没有实际应用的示例,所以,后 ...
- w3wp.exe已附加有调试器,但没有该调试器配置为调试此未经处理的异常,若要调试此异常,必须分离当前的调试器。
之前通过使用VS2010附加进程调试项目后,今天开机发现调试本机的项目报错如下图: 到网上到处查看无果,经过反复实验找到解决方法,我的项目是发布到IIS的 1.首先删除IIS上面的项目 2.在VS右击 ...
- C#继承中的override(重写)与new(覆盖)用法
刚接触C#编程,我也是被override与new搞得晕头转向.于是花了点时间翻资料,看博客,终于算小有领悟,把学习笔记记录于此. 首先声明一个父类Animal类,与继承Animal的两个子类Dog类与 ...
- 【Python】Non-ASCII character '\xe6' 错误解决方法
刚刚在写Python程序的时候遇到了一个问题,无论是在程序中什么地方出现中文字符,都会出现如下错误 SyntaxError: Non-ASCII character '\xe6' 网上查阅了一下这应该 ...
- SQL系统函数的使用(实验五)
SQL系统函数的使用(试验5) 函数在查询语句中的使用 查询员工的姓名和日工资(保留1位小数): 查询并显示部门号为01和02的所有员工的姓名首字及岗位: 查询并显示所有员工的姓名及工龄: 查询199 ...
- C#实现的Redis扩展项目(二次封装)
Redis在当下的互联网项目当中的普及率我想都不用多说了,本文要介绍的這个项目是基于我对Redis理解程度的基础上写的一个公共类库项目,希望对各位童鞋有所帮助,也欢迎各位对我都内容提出更好的意见. 由 ...
- centos6.5安装rabbitmq3.6.14
The minimum version of Erlang/OTP required to run RabbitMQ server 3.6.0 through 3.6.14 is R16B03. St ...