ASP.NET MVC关于Ajax以及Jquery的无限级联动
---恢复内容开始---
第一次发表博文,发表博文的目的是巩固自己的技术,也能够共享给大家。写的不好的地方,希望大家多给给意见。老司机勿喷
数据结构()
NewsTypeId 新闻ID,
NewsTypeName 新闻名称
NewsTypeParentId 父级ID
后台语言:ASP.NET MVC4
后台代码:
/// <summary>
/// JSON格式的List集合
/// </summary>
/// <returns></returns>
public JsonResult FnNewsTypeList()
{
int NewsTypeParentId = -1;
if (!string.IsNullOrEmpty(Request["NewsTypeParentId"]))
{
NewsTypeParentId = Convert.ToInt32(Request["NewsTypeParentId"]);
}
Maticsoft.BLL.NewsType NTbll = new Maticsoft.BLL.NewsType();
StringBuilder strWhere = new StringBuilder();
if (NewsTypeParentId != -1)
{
strWhere.AppendLine(" AND NewsTypeParentId ='" + NewsTypeParentId+"'");
}
List<Maticsoft.Model.NewsType> NTList = NTbll.NewsTypeList(strWhere.ToString());
return Json(NTList);
}
页面布局:
<div class="form-group ">
<label class="col-sm-3 control-label">所属类型:</label>
<div class="col-sm-8" id="cat">
<select id="NewsTypeParentId_0" onchange="FirstChange(0)" name="NewsTypeParentId" class="form-control" aria-describedby="firstname-error" aria-invalid="true">
<option value="0">请选择</option>
<option value="1">1</option>
</select>
</div>
</div>
Jquery语言:
Jquery代码:
//页面第一次加载时,将父级为最高级的类型读取出来
<script>
$(function () {
$.ajax({
type: "POST",
url: "/NewsType/FnNewsTypeList",
data: {
NewsTypeParentId: 0
},
dataType: "JSON",
success: function (data) {
var SelectArray = new Array();
SelectArray.push("<option value=\"0\">请选择</option>")
for (var i = 0; i < data.length; i++) {
//使用Array拼接Html页面
SelectArray.push("<option value=\"");
SelectArray.push(data[i].NewsTypeId);
SelectArray.push("\">");
SelectArray.push(data[i].NewsTypeName);
SelectArray.push("</option>");
}
//寻找最高级分类追加数据
var SelectDom = $("[name=NewsTypeParentId]:eq(0)")
SelectDom.find("option").remove()
//Array 的 join 方法,将所有的Html内容连接
SelectDom.append(SelectArray.join(""))
}
})
})
//下拉框发生改变触发的时间
ThisId 是当前所属Select的Id属性
ChildId 是当前Select的下一级的Select 的ID属性
FirstChange是当下拉框改变时执行的第一个事件
function FirstChange(ThisId) {
var ChildId= parseInt(ThisId) + 1;
SecondChange(ThisId, ChildId)
}
//SecondChange 是寻找被点击Select下的所有下N级Select,如果存在,则先移除所有下级Select
function SecondChange(ThisId, ChildId) {
$("#NewsTypeParentId_" + ThisId)
var ParentVal = $("#NewsTypeParentId_" + ThisId).val();
//while循环判断下一个select 是否存在,如存在则删除直到不存在为止
doChildId= ChildId;
do {
if ($("#NewsTypeParentId_" + doChildId).length > 0) {
$("#NewsTypeParentId_" + doChildId).remove();
doChildId++;
} else {
break;
}
} while (1)
if (ParentVal != '') {
//当被点击的Select值存在时,这时已将其下属的所有Select清楚,重新调用数据进行生成
NewsTypeParentId(ParentVal, ChildId);
}
}
//Ajax读取数据进行追加生成
function NewsTypeParentId(ParentVal, ChildId) {
if (ParentVal != 0) {
$.ajax({
type: "POST",
url: "/NewsType/FnNewsTypeList",
data: {
NewsTypeParentId: ParentVal
},
dataType: "JSON",
success: function (data) {
//返回值data是JSON格式,当data存在数据时,表示存在下级,进行数据处理和Html生成
//Select的ID属性值为NewsTypeParentId_? 从第一级开始,依次为0,1,2,3,4...
if (data.length > 0) {
var SelectArray = new Array();
SelectArray.push("");
SelectArray.push("<select id=\"NewsTypeParentId_");
SelectArray.push(ChildId);
SelectArray.push("\" onchange=\"FirstChange(");
SelectArray.push(ChildId);
SelectArray.push(")\" name=\"NewsTypeParentId\" class=\"form-control\" ");
SelectArray.push("aria-describedby=\"firstname-error\" aria-invalid=\"true\">");
SelectArray.push("<option value=\"0\">请选择</option> ")
for (var i = 0; i < data.length; i++) {
SelectArray.push("<option value=\"");
SelectArray.push(data[i].NewsTypeId);
SelectArray.push("\">");
SelectArray.push(data[i].NewsTypeName);
SelectArray.push("</option> ");
}
SelectArray.push("</select>");
//最后将此Select追加至DIV末端
$("#cat").append(SelectArray.join(""))
}
}
})
}
}
Jquery最后传参数添加数据时,做某些数据处理
//ParentVal是最后一级Select的值,当未选中任何项时,则选择上一级数据
var ParentVal = $("[name=NewsTypeParentId]:last").val();
if (ParentVal == 0) {
//寻找最后一个Select的索引
//将索引-1
var SelectIndex = $("[name=NewsTypeParentId]:last").index();
SelectIndex = SelectIndex - 1;
ParentVal = $("[name=NewsTypeParentId]:eq(" + SelectIndex + ")").val();
}
</script>
---恢复内容结束---
ASP.NET MVC关于Ajax以及Jquery的无限级联动的更多相关文章
- ASP.NET MVC 实现AJAX跨域请求方法《1》
ASP.NET MVC 实现AJAX跨域请求的两种方法 通常发送AJAX请求都是在本域内完成的,也就是向本域内的某个URL发送请求,完成部分页面的刷新.但有的时候需要向其它域发送AJAX请求,完成数据 ...
- [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传
原文 [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传 Fine Uploader(http://fineuploader.com/)是一个实现 ajax 上传文件 ...
- Asp.Net MVC 使用 Ajax
Asp.Net MVC 使用 Ajax Ajax 简单来说Ajax是一个无需重新加载整个网页的情况下,可以更新局部页面或数据的技术(异步的发送接收数据,不会干扰当前页面). Ajax工作原理 Ajax ...
- Asp.Net MVC Unobtrusive Ajax
1. Unobtrusive JavaScript介绍 说到Unobtrusive Ajax,就要谈谈UnobtrusiveJavaScript了,所谓Unobtrusive JavaScript ...
- ASP.NET MVC之Ajax如影随行
一.Ajax的前世今生 我一直觉得google是一家牛逼的公司,为什么这样说呢?<舌尖上的中国>大家都看了,那些美食估计你是百看不厌,但是里边我觉得其实也有这样的一个哲学:关于食材,对于种 ...
- ASP.NET MVC 实现 AJAX 跨域请求
ASP.NET MVC 实现AJAX跨域请求的两种方法 和大家分享下Ajax 跨域的经验,之前也找了好多资料,但是都不行,后来看到个可行的修改了并测试下 果然OK了 希望对大家有所帮助! 通常发送 ...
- ASP.NET MVC 学习笔记-7.自定义配置信息 ASP.NET MVC 学习笔记-6.异步控制器 ASP.NET MVC 学习笔记-5.Controller与View的数据传递 ASP.NET MVC 学习笔记-4.ASP.NET MVC中Ajax的应用 ASP.NET MVC 学习笔记-3.面向对象设计原则
ASP.NET MVC 学习笔记-7.自定义配置信息 ASP.NET程序中的web.config文件中,在appSettings这个配置节中能够保存一些配置,比如, 1 <appSettin ...
- asp.net mvc 使用ajax请求 控制器 (PartialViewResult)分部的action,得到一个分部视图(PartialView)的HTML,进行渲染
在asp.net mvc 使用ajax请求获取数据的时候,我们一般是返回json或者xml,然后解析这些数据进行渲染,这样会比较麻烦,可以请求一个 分部action,返回一个分部视图 直接可以渲染,不 ...
- 在Asp.Net MVC中用Ajax回调后台方法
在Asp.Net MVC中用Ajax回调后台方法基本格式: var operData = ...; //传递的参数(action中定义的) var type = ...; //传递的参数(action ...
随机推荐
- 如何一步一步用DDD设计一个电商网站(八)—— 会员价的集成
阅读目录 前言 建模 实现 结语 一.前言 前面几篇已经实现了一个基本的购买+售价计算的过程,这次再让售价丰满一些,增加一个会员价的概念.会员价在现在的主流电商中,是一个不大常见的模式,其带来的问题是 ...
- 为你的Web程序加个启动画面
.Net开发者一定熟悉下面这个画面: 这就是宇宙第一IDE Visual Studio的启动画面,学名叫Splash Screen(或者Splash Window).同样,Javar们一定对Eclip ...
- Oracle 的基本操作符
!= 不等于 select empno,ename,job from scott.emp where job!='manager' ^= 不等于 select empno,ename,job from ...
- 23种设计模式--中介者模式-Mediator Pattern
一.中介者模式的介绍 中介者模式第一下想到的就是中介,房子中介,婚姻中介啊等等,当然笔者也希望来个婚姻中介给我介绍一个哈哈哈,,回归正题中介者模式分成中介者类和用户类,根据接口编程的方式我们再 ...
- Android消息传递之基于RxJava实现一个EventBus - RxBus
前言: 上篇文章学习了Android事件总线管理开源框架EventBus,EventBus的出现大大降低了开发成本以及开发难度,今天我们就利用目前大红大紫的RxJava来实现一下类似EventBus事 ...
- windows+nginx+iis+redis+Task.MainForm构建分布式架构 之 (nginx+iis构建服务集群)
本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,由标题就能看出此内容不是一篇分享文章能说完的,所以我打算分几篇分享文章来讲解,一步一步实现分 ...
- 【原创】免费申请SSL证书【用于HTTPS,即是把网站从HTTP改为HTTPS,加密传输数据,保护敏感数据】
今天公司有个网站需要改用https访问,所以就用到SSL证书.由于沃通(以前我是在这里申请的)暂停了免费的SSL证书之后,其网站推荐了新的一个网站来申请证书,所以,今天因为刚好又要申请一个证书,所以, ...
- android studio你可能忽视的细节——启动白屏?drawable和mipmap出现的意义?这里都有!!!
android studio用了很久了,也不知道各位小伙伴有没有还在用eclipse的,如果还有,楼主真心推荐转到android studio来吧,毕竟亲儿子,你会知道除了启动速度稍微慢些,你找不到一 ...
- Android—自定义开关按钮实现
我们在应用中经常看到一些选择开关状态的配置文件,做项目的时候用的是android的Switch控件,但是感觉好丑的样子………… 个人认为还是自定义的比较好,先上个效果图:
- Atitit godaddy 文件权限 root权限设置
Atitit godaddy 文件权限 root权限设置 1. ubuntu需要先登录,再su切换到root1 2. sudo 授权许可使用的su,也是受限制的su1 3. ubuntu默认吗roo ...