写了ajax实现级联下拉框,考虑常用,并且级联个数随不同业务个数不同,于是就整理了一下,实现了 ajax + N级联动 下拉框的效果

效果图

HTML 代码

    <h2> 省级联动</h2>
<div class="city" >
<select id="SelProvince" class="select"></select>
<select id="SelCity" class="select"></select>
<select id="SelArea" class="select"></select>
<select id="SelXian" class="select"></select>
</div> <h2> 市区联动</h2>
<div class="city" >
<select id="Select1" class="select"></select>
<select id="Select2" class="select"></select>
<select id="Select3" class="select"></select>
</div>

js 绑定

 引入jQuery 和 jquery.cascadeselect.js 两个文件(下面会贴出文件下载地址)
 <script type="text/javascript">
$(function () { $.fn.CascadeSelect({
url: '/CascadeSelect/CascadeSelect.ashx', //返回Json数据的一般处理文件
idKey: 'Id', // 绑定下拉框实际值的字段
nameKey: 'Name', // 绑定下拉框显示值的字段
casTopId: 0, // 顶级节点ParentId
casCount: 4, // 级联个数
casObjId: ['SelProvince', 'SelCity', 'SelArea', 'SelXian'], // 级联下拉框id
casDefVal: ['全国', 5, '益阳', 22], // 级联默认值(Id,Name都可以)
}); $.fn.CascadeSelect({
url: '/CascadeSelect/CascadeSelect.ashx', //返回Json数据的一般处理文件
idKey: 'Id', // 绑定下拉框实际值的字段
nameKey: 'Name', // 绑定下拉框显示值的字段
casTopId: 1, // 顶级节点ParentId
casCount: 3, // 级联个数
casObjId: ['Select1', 'Select2', 'Select3'], // 级联下拉框id
casDefVal: [5, '益阳', 22], // 级联默认值(Id,Name都可以)
});
});
</script>

jquery.cascadeselect.js 源码:

$(function ($) {
cas_settings = {};
$.fn.CascadeSelect = function (options) { var cas_setId = options['casObjId'][0];
cas_settings[cas_setId] =
{
url: 'xxoo.ashx', //返回Json数据的一般处理文件
idKey: 'id',
nameKey: 'name',
casTopId: 0 , // 顶级节点ParentId
casCount: 3, // 级联个数
casObjId: [], // 级联下拉框id
casDefVal: [], // 级联默认值
};
$.extend(cas_settings[cas_setId], options);
// ----------------->
} // 加载级联数据
function LoadCasData(curLevel, cas_setId, ParentID) {
if (curLevel > cas_settings[cas_setId].casCount) return; var cid = cas_settings[cas_setId].casObjId[curLevel - 1]; // 下拉框id
var cdefval = cas_settings[cas_setId].casDefVal[curLevel - 1]; //默认值
var idKey = cas_settings[cas_setId].idKey;
var nameKey = cas_settings[cas_setId].nameKey;
var CPID = 0; //市级所需要的父级ID var curObj = $('#' + cid); // 当前下拉框
curObj.empty(); //清空下拉框
if (ParentID == undefined) {
LoadCasData(curLevel + 1, cas_setId);
return;
} $.ajax({
url: cas_settings[cas_setId].url, type: 'post', data: { Level: curLevel, ParentID: ParentID }, dataType: 'json', async: false
, success: function (data) {
if (data.length == 0) {
LoadCasData(curLevel + 1, cas_setId); // 加载子项数据
return;
} CPID = data[0][idKey]; //如果没有传入参数,系统默认父级第一个ID
for (var i = 0; i < data.length; i++) {
if (data[i][idKey] == cdefval || data[i][nameKey] == cdefval ) {
CPID = data[i][idKey]; // 选中默认值
curObj.append(" <option value='" + data[i][idKey] + "' selected='selected'>" + data[i][nameKey] + "</option>");
} else {
curObj.append(" <option value='" + data[i][idKey] + "'>" + data[i][nameKey] + "</option>");
}
} LoadCasData(curLevel + 1, cas_setId, CPID); // 加载子项数据
return;
}
, error: function () {
console.log('加载数据出错!');
}
}); } // 设置下拉框级别
function SetCasLevel(cas_setId) {
for (var i = 0; i < cas_settings[cas_setId].casCount; i++) {
var cid = cas_settings[cas_setId].casObjId[i]; // 下拉框id
$('#' + cid).data('level', i + 1); // 当前下拉框级别
$('#' + cid).data('setid', cas_setId); // 配置信息Id //下拉框改变
$('#' + cid).change(function () {
var CPID = $(this).val();
LoadCasData($(this).data('level') + 1, $(this).data('setid'),CPID);
});
}
} // 页面加载
$(function () {
for (var cas_setId in cas_settings) {
console.log(cas_setId);
SetCasLevel(cas_setId);
LoadCasData(1, cas_setId, cas_settings[cas_setId].casTopId);
}
}); });

往后台传递的参数:

Level 级联级别 1开始
ParentID 父级ID

后台页面两种情况:

1、省市区是一个表(表结构是Id,Name,ParentId) 自联接查询的话,后台页面根据ParentId查询数据即可
2、省市区在不同的表,可一个根据 Level 级联级别分别查询数据,但是省市区返回数据实体得一样,也就是列名得一致
     返回数据的格式:[{"Id":value,"Name":value},{"Id":value,"Name":value}] 
     绑定的时候可以设置这两个字段值:(idKey: 'Id', // 绑定下拉框实际值的字段 nameKey: 'Name', // 绑定下拉框显示值的字段)

(js文件,源码)案例下载:http://download.csdn.net/detail/qq_21533697/8968013
   交流群 : 84479667

----------------end

ajax 多级联动 下拉框 Demo的更多相关文章

  1. JQuery Easyui/TopJUI 创建多级联动下拉框(纯HTML实现!!!)

    JQuery Easyui/TopJUI 创建多级联动下拉框(纯HTML实现!!!) 效果展示: 代码如下: <form data-toggle="topjui-form"& ...

  2. bootstrap 多级联动下拉框

    <!DOCTYPE HTML> <html lang="zh-CN"> <head> <meta charset="UTF-8& ...

  3. JQ与AJAX 省市区三级联动下拉框

    用于初学者学习基本的联动下拉框,废话不多说,见代码 首先看控制器里的3个下拉框对应代码: public ActionResult GetProvinceList() { ProvinceReposit ...

  4. jQuery cxSelect 多级联动下拉菜单

    随着电商热门,这种多层次的互动更充分地体现在下拉菜单,最明显的是多级联动地址下拉选择,因此,这里是一个简单的分享 jQuery cxSelect 多级联动下拉菜单 cxSelect 它是基于 jQue ...

  5. Android实现三级联动下拉框 下拉列表spinner

    Android实现(省.市.县)三级联动下拉框 下拉列表spinner 转载请注明出处: http://www.goteny.com/articles/2013/11/46.html http://w ...

  6. jquery+html三级联动下拉框

    jquery+html三级联动下拉框及详情页面加载时的select初始化问题   html写的三个下拉框,如下: <select name="ddlQYWZYJ" id=&q ...

  7. 项目总结01:JSP mysql SpringMvc下中国省市县三级联动下拉框

    JSP mysql SpringMvc下中国省市县三级联动下拉框 关键词 JSP  mysql数据库  SpringMvc  ajax   Controller层  Service层  中国地区  省 ...

  8. Vue.js组件之联动下拉框

    Html代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  9. SharePoint 2013 使用查阅项实现联动下拉框

    SharePoint列表使用中,经常会用到下拉框,而有些特殊的需求,会用到联动的下拉框,在SharePoint中默认没有这样的字段,所以如果实现,我们需要自己想办法. 这里,我们介绍如何使用JQuer ...

随机推荐

  1. Razor基础语法一

    目录: 什么是Razor? 渲染HTML Razor语法 隐式 Razor 表达式 显式 Razor 表达式 什么是Razor? Razor是基于服务端代码转换成网页的标记语法.语法主要包括Razor ...

  2. SQL SERVER 竖表变成横表

    现有数据如下: Sql: select a.MODELID, max( case a.PNAME when'计划开始' then a.PVALUE end) as RStart, max( case ...

  3. 自己动手写计算器v1.1

    这个改动主要是使用工厂模式替代了简单工厂模式,这样做的好处是如果以后我们要扩充其他运算时,就不用总是去修改工厂类, 这是可以采取工厂模式,主要是将原来简单工厂类的逻辑判断分离出来,将它作为一个借口,与 ...

  4. Monkey Patch/Monkey Testing/Duck Typing/Duck Test

    Monkey Patch Monkey Testing Duck Typing Duck Test

  5. 让linux开机默认开启小键盘

     linux默认开机不开启数字键盘numberlock,每次输入开机密码还得劳烦自己去点亮指示灯,让此灯开机自动点亮,需要一个软件才行,就是numlockx了,可以通过yum安装:yuminstall ...

  6. FunDA(0)- Functional Data Access accessible to all

    大数据.多核CPU驱动了函数式编程模式的兴起.因为函数式编程更适合多线程.复杂.安全的大型软件编程.但是,对许多有应用软件开发经验的编程者来说,函数式编程模式是一种全新的.甚至抽象的概念,可能需要很长 ...

  7. 如何写出安全的API接口(参数加密+超时处理+私钥验证+Https)- 续(附demo)

    上篇文章说到接口安全的设计思路,如果没有看到上篇博客,建议看完再来看这个. 通过园友们的讨论,以及我自己查了些资料,然后对接口安全做一个相对完善的总结,承诺给大家写个demo,今天一并放出. 对于安全 ...

  8. MySQL数据库不能远程访问的解决办法

    MySQL数据库不允许从远程访问怎么办? 下面提供两种方法: 1.改表法 MySQL的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入mysql后,更改 ...

  9. css图片精灵

    <ul> <li class="top"> <em>01</em> <p><a href="http:/ ...

  10. mui 手势事件配置

    在开发中监听双击屏幕事件时不起作用,需要在mui.init方法的gestureConfig参数中设置需要监听的手势事件 手势事件配置: 根据使用频率,mui默认会监听部分手势事件,如点击.滑动事件:为 ...