---恢复内容开始---

第一次发表博文,发表博文的目的是巩固自己的技术,也能够共享给大家。写的不好的地方,希望大家多给给意见。老司机勿喷

数据结构()

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的无限级联动的更多相关文章

  1. ASP.NET MVC 实现AJAX跨域请求方法《1》

    ASP.NET MVC 实现AJAX跨域请求的两种方法 通常发送AJAX请求都是在本域内完成的,也就是向本域内的某个URL发送请求,完成部分页面的刷新.但有的时候需要向其它域发送AJAX请求,完成数据 ...

  2. [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传

    原文 [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传 Fine Uploader(http://fineuploader.com/)是一个实现 ajax 上传文件 ...

  3. Asp.Net MVC 使用 Ajax

    Asp.Net MVC 使用 Ajax Ajax 简单来说Ajax是一个无需重新加载整个网页的情况下,可以更新局部页面或数据的技术(异步的发送接收数据,不会干扰当前页面). Ajax工作原理 Ajax ...

  4. Asp.Net MVC Unobtrusive Ajax

    1.   Unobtrusive JavaScript介绍 说到Unobtrusive Ajax,就要谈谈UnobtrusiveJavaScript了,所谓Unobtrusive JavaScript ...

  5. ASP.NET MVC之Ajax如影随行

    一.Ajax的前世今生 我一直觉得google是一家牛逼的公司,为什么这样说呢?<舌尖上的中国>大家都看了,那些美食估计你是百看不厌,但是里边我觉得其实也有这样的一个哲学:关于食材,对于种 ...

  6. ASP.NET MVC 实现 AJAX 跨域请求

    ASP.NET MVC 实现AJAX跨域请求的两种方法 和大家分享下Ajax 跨域的经验,之前也找了好多资料,但是都不行,后来看到个可行的修改了并测试下 果然OK了   希望对大家有所帮助! 通常发送 ...

  7. 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 ...

  8. asp.net mvc 使用ajax请求 控制器 (PartialViewResult)分部的action,得到一个分部视图(PartialView)的HTML,进行渲染

    在asp.net mvc 使用ajax请求获取数据的时候,我们一般是返回json或者xml,然后解析这些数据进行渲染,这样会比较麻烦,可以请求一个 分部action,返回一个分部视图 直接可以渲染,不 ...

  9. 在Asp.Net MVC中用Ajax回调后台方法

    在Asp.Net MVC中用Ajax回调后台方法基本格式: var operData = ...; //传递的参数(action中定义的) var type = ...; //传递的参数(action ...

随机推荐

  1. [linux]阿里云主机的免登陆安全SSH配置与思考

    公司服务器使用的第三方云端服务,即阿里云,而本地需要经常去登录到服务器做相应的配置工作,鉴于此,每次登录都要使用密码是比较烦躁的,本着极速思想,我们需要配置我们的免登陆. 一 理论概述 SSH介绍 S ...

  2. 探索C#之6.0语法糖剖析

    阅读目录: 自动属性默认初始化 自动只读属性默认初始化 表达式为主体的函数 表达式为主体的属性(赋值) 静态类导入 Null条件运算符 字符串格式化 索引初始化 异常过滤器when catch和fin ...

  3. ASP.NET MVC5+EF6+EasyUI 后台管理系统(69)-微信公众平台开发-功能概述

    系列目录 为什么要先发这个文章? 因为接下来的文章是关于微信开发的系列,心中一定要有一个概念,知道自己接下来要做什么功能. 而且微信到处都是坑,我首先要把微信与本地跑通起来才敢发布,否则中间出现坑导致 ...

  4. ASP.NET Core的路由[4]:来认识一下实现路由的RouterMiddleware中间件

    虽然ASP.NET Core应用的路由是通过RouterMiddleware这个中间件来完成的,但是具体的路由解析功能都落在指定的Router对象上,不过我们依然有必要以代码实现的角度来介绍一下这个中 ...

  5. My TWI

    前言 对TWI没有什么特别的印象,因为有一个更出名的TWU,而我去年又刚好错过了它,因此TWU的光辉完全掩盖了TWI.对TWI印象最深的是在邮件中看到的38th北京的这期,看到他们的图文记录,在圈子中 ...

  6. webapp应用--模拟电子书翻页效果

    前言: 现在移动互联网发展火热,手机上网的用户越来越多,甚至大有超过pc访问的趋势.所以,用web程序做出仿原生效果的移动应用,也变得越来越流行了.这种程序也就是我们常说的单页应用程序,它也有一个英文 ...

  7. Java程序员:工作还是游戏,是该好好衡量一下了

    前阵子我终于下定决心,删掉了硬盘里所有的游戏. 身为一个程序猿,每天都要和各种新技术打交道,闲暇时间,总还得看一下各大论坛,逛逛博客园啥的,给自己充充电.游戏的话,其实我自小就比较喜欢,可以算是一种兴 ...

  8. AbpZero--2.如何启动

    1.直接启动 VS中直接启动 2.IIS站点 IIS中配置一个站点来启动(推荐) 3.登录 系统默认创建2个用户 默认用户名:admin 密码:123qwe 租户:Default  默认用户名:adm ...

  9. FullCalendar应用——整合农历节气和节日

    FullCalendar用来做日程管理功能非常强大,但是唯一不足的地方是没有将中国农历历法加进去,今天我将结合实例和大家分享如何将中国农历中的节气和节日整合到FullCalendar中,从而增强其实用 ...

  10. 易用BPM时代,企业如何轻松驾驭H3?

    众所周知,BPM作为企业发展的推动力,能敏捷高效的融合业务流程和信息资源.通过综合考虑流程的成本.效率.质量等方面因素,用IT系统将调整后的流程固化下来,从而降低企业管理成本,提高内部运营效率,提升企 ...