基于MVC3方式实现下拉列表联动(JQuery)


Posted in Javascript onSeptember 02, 2013

上次项目中遇到一个需要多个下拉列表联动的操作,今天有空将实现方式整理以便以后参考。
要达到的效果是,点击一个下拉框,则另一个下拉框的值发生对应变化。如:选择中国,则另个一下拉框里显示中国各个省份。
传统的HTML方式比较简单,实际上基于MVC的实现方式也大同小异。

直接上代码:

public class DP_Provice 
{ 
public int proviceID { get; set; } 
public string ProviceName { get; set; } 
public int ProviceNode { get; set; } 
public virtual List<DP_City> citySource { get; set; } 
} public class DP_City 
{ 
public int CityNode { get; set; } 
public string CityName { get; set; } 
public string ProviceNode { get; set; } 
}

对以上涉及到的实体类予以赋值,暂时使用一个静态类初始化简单数据:
public static class DPDataSource 
{ 
public static List<DP_Provice> InitalData() 
{ 
List<DP_Provice> source = new List<DP_Provice> 
{ 
new DP_Provice{ ProviceNode=1, ProviceName="北京", citySource=new List<DP_City>{ 
new DP_City{ 
CityNode=11, CityName="北京海淀" 
}, 
new DP_City{ 
CityNode=12,CityName="北京西城" 
} 
}}, 
new DP_Provice{ ProviceNode=2, ProviceName="山东", citySource=new List<DP_City>{ 
new DP_City{ 
CityNode=21, CityName="济南" 
}, 
new DP_City{ 
CityNode=22,CityName="德州" 
} 
}}, 
new DP_Provice{ ProviceNode=3, ProviceName="河北", citySource=new List<DP_City>{ 
new DP_City{ 
CityNode=31, CityName="石家庄" 
}, 
new DP_City{ 
CityNode=32,CityName="衡水" 
} 
}} 
}; return source; 
} 
}

具体在Controller中的调用,因为使用的JQuery中的AJAX方式,所以返回的结果类型为Json;
public ActionResult Index() 
{ 
return View("DPShow"); 
} 
List<DP_Provice> source = DPDataSource.InitalData(); public JsonResult GetProvinceSource() 
{ 
if (source == null || source.Count < 0) 
{ 
source = DPDataSource.InitalData(); 
} 
return Json(source, JsonRequestBehavior.AllowGet); 
} 
public JsonResult GetCitySource(string proviceName) 
{ 
source = DPDataSource.InitalData(); 
List<DP_City> citySource = new List<DP_City>(); 
citySource = source.Where(a => a.ProviceNode.ToString().Contains(proviceName)).First().citySource; 
return Json(citySource, JsonRequestBehavior.AllowGet); 
}

数据准备完毕,此时需要Razor视图中进行绑定和展示,代码如下:
@model MvcApplication.Models.DP_Provice 
@{ 
ViewBag.Title = "DPShow"; 
Layout = "~/Views/Shared/_Layout.cshtml"; 
} 
<script type="text/javascript"> 
$(function myfunction() { 
GetPlant(); 
//初始化省份数据 
$("#ddlProvince").change(function ff() { //设置当省份下拉列表发生变化时,更新城市数据列表 
GetCity(); 
}); 
}); function GetPlant() { 
$("#ddlProvince").empty(); 
var url = "/Dropdown/GetProvinceSource/"; 
$.getJSON(url, function (data) { 
$.each(data, function (i, item) { 
$("<option></option>") 
.val(item["ProviceNode"]) 
.text(item["ProviceName"]) 
.appendTo($("#ddlProvince")); 
}); 
GetCity(); 
}); 
} 
function GetCity() { 
$("#ddlCity").empty(); 
var temp=$("#ddlProvince").val(); 
var url ="@Url.Action("GetCitySource", "Dropdown")" ; 
//使用MVC3中Url.Action 方法参数依次为:aciton ; controller ; area ; 
$.getJSON(url,{"proviceName":temp}, function (data) { 
//中间需要用到参数 所以采用在getJSON方法中实现 
$.each(data, function (i, item) { 
$("<option></option>") 
.val(item["CityNode"]) 
.text(item["CityName"]) 
.appendTo($("#ddlCity")); 
}); 
}); 
} 
</script> 
<! DOCTYPE html /> 
<h2> 
下拉列表联动</h2> 
<table> 
<tr> 
<td> 
<select id="ddlProvince" /> 
</td> 
<td> 
<select id="ddlCity" /> 
</td> 
</tr> 
</table>

说明:
一般来讲,采用MVC实现下拉列表绑定可以有多种方式,主要是数据绑定方式可以使用JQuery中的Ajax 方式,同时也可以使用自定义的基于MVC 的 Url.Acion 方式,个人建议使用基于MVC 的 Url.Acion。
一来是支持方式比较灵活,如果中间涉及到数据类型复杂,可以自定义,实现数据封装;
二来是JQuery 中URL在传递参数时需要格式化,否则将无法找到指定的Action。
如有大家对上述说法有异议或者更好的实现方案,请给予指正或说明,谢谢。
Javascript 相关文章推荐
js弹窗返回值详解(window.open方式)
Jan 11 Javascript
jquery实现简单Tab切换菜单效果
Jul 17 Javascript
JS取模、取商及取整运算方法示例
Oct 13 Javascript
微信小程序 二维码canvas绘制实例详解
Jan 06 Javascript
js+html制作简单验证码
Feb 16 Javascript
VUE多层路由嵌套实现代码
May 15 Javascript
canvas+gif.js打造自己的数字雨头像的示例代码
Oct 26 Javascript
全新打包工具parcel零配置vue开发脚手架
Jan 11 Javascript
jQuery动态操作表单示例【基于table表格】
Dec 06 jQuery
vue.js实现图书管理功能
Sep 24 Javascript
微信小程序实现签字功能
Dec 23 Javascript
vue使用v-model进行跨组件绑定的基本实现方法
Apr 28 Vue.js
javascript模块化是什么及其优缺点介绍
Sep 02 #Javascript
火狐下table中创建form导致两个table之间出现空白
Sep 02 #Javascript
js的alert弹出框出现乱码解决方案
Sep 02 #Javascript
javascript中的window.location.search方法简介
Sep 02 #Javascript
js Math 对象的方法
Sep 01 #Javascript
javascript ready和load事件的区别示例介绍
Aug 30 #Javascript
文本有关的样式和jQuery求对象的高宽问题分别说明
Aug 30 #Javascript
You might like
服务器变量 $_SERVER 的深入解析
2013/07/02 PHP
laravel 中如何使用ajax和vue总结
2017/08/16 PHP
PHP实现普通hash分布式算法简单示例
2018/08/06 PHP
TP5框架请求响应参数实例分析
2019/10/17 PHP
Javascript 不能释放内存.
2006/09/07 Javascript
JS实现可改变列宽的table实例
2013/07/02 Javascript
Javascript获取表单名称(name)的方法
2015/04/02 Javascript
JS数组array元素的添加和删除方法代码实例
2015/06/01 Javascript
js数组去重的方法汇总
2015/07/29 Javascript
javascript实现tab响应式切换特效
2016/01/29 Javascript
jQuery实现图片局部放大镜效果
2016/03/17 Javascript
jQuery仿写百度百科的目录树
2017/01/03 Javascript
jQuery中ajax获取数据赋值给页面的实例
2017/12/31 jQuery
JS高级技巧(简洁版)
2018/07/29 Javascript
[03:02]2020完美世界城市挑战赛(秋季赛)总决赛回顾
2021/03/11 DOTA
Python返回真假值(True or False)小技巧
2015/04/10 Python
python中下标和切片的使用方法解析
2019/08/27 Python
Anaconda之conda常用命令介绍(安装、更新、删除)
2019/10/06 Python
树莓派极简安装OpenCv的方法步骤
2019/10/10 Python
python numpy库np.percentile用法说明
2020/06/08 Python
Django多个app urls配置代码实例
2020/11/26 Python
Python读取ini配置文件传参的简单示例
2021/01/05 Python
澳大利亚100%丝绸多彩度假装商店:TheSwankStore
2019/09/04 全球购物
毕业生求职推荐信
2013/11/04 职场文书
小学生防溺水广播稿
2014/01/12 职场文书
毕业生自荐书
2014/02/03 职场文书
《藏戏》教学反思
2014/02/11 职场文书
党员违纪检讨书
2014/02/18 职场文书
活动总结书
2014/05/08 职场文书
2014副局长群众路线对照检查材料思想汇报
2014/09/22 职场文书
万能检讨书2000字
2014/10/17 职场文书
文明家庭事迹材料
2014/12/20 职场文书
纪委立案决定书
2015/06/24 职场文书
小学班级管理心得体会
2016/01/07 职场文书
2016大学生毕业实习心得体会
2016/01/23 职场文书
科学家研发出新型速效酶,可在 24 小时内降解塑料制品
2022/04/29 数码科技