ajax 多级联动 下拉框 Demo
写了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的更多相关文章
- JQuery Easyui/TopJUI 创建多级联动下拉框(纯HTML实现!!!)
JQuery Easyui/TopJUI 创建多级联动下拉框(纯HTML实现!!!) 效果展示: 代码如下: <form data-toggle="topjui-form"& ...
- bootstrap 多级联动下拉框
<!DOCTYPE HTML> <html lang="zh-CN"> <head> <meta charset="UTF-8& ...
- JQ与AJAX 省市区三级联动下拉框
用于初学者学习基本的联动下拉框,废话不多说,见代码 首先看控制器里的3个下拉框对应代码: public ActionResult GetProvinceList() { ProvinceReposit ...
- jQuery cxSelect 多级联动下拉菜单
随着电商热门,这种多层次的互动更充分地体现在下拉菜单,最明显的是多级联动地址下拉选择,因此,这里是一个简单的分享 jQuery cxSelect 多级联动下拉菜单 cxSelect 它是基于 jQue ...
- Android实现三级联动下拉框 下拉列表spinner
Android实现(省.市.县)三级联动下拉框 下拉列表spinner 转载请注明出处: http://www.goteny.com/articles/2013/11/46.html http://w ...
- jquery+html三级联动下拉框
jquery+html三级联动下拉框及详情页面加载时的select初始化问题 html写的三个下拉框,如下: <select name="ddlQYWZYJ" id=&q ...
- 项目总结01:JSP mysql SpringMvc下中国省市县三级联动下拉框
JSP mysql SpringMvc下中国省市县三级联动下拉框 关键词 JSP mysql数据库 SpringMvc ajax Controller层 Service层 中国地区 省 ...
- Vue.js组件之联动下拉框
Html代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...
- SharePoint 2013 使用查阅项实现联动下拉框
SharePoint列表使用中,经常会用到下拉框,而有些特殊的需求,会用到联动的下拉框,在SharePoint中默认没有这样的字段,所以如果实现,我们需要自己想办法. 这里,我们介绍如何使用JQuer ...
随机推荐
- Razor基础语法一
目录: 什么是Razor? 渲染HTML Razor语法 隐式 Razor 表达式 显式 Razor 表达式 什么是Razor? Razor是基于服务端代码转换成网页的标记语法.语法主要包括Razor ...
- SQL SERVER 竖表变成横表
现有数据如下: Sql: select a.MODELID, max( case a.PNAME when'计划开始' then a.PVALUE end) as RStart, max( case ...
- 自己动手写计算器v1.1
这个改动主要是使用工厂模式替代了简单工厂模式,这样做的好处是如果以后我们要扩充其他运算时,就不用总是去修改工厂类, 这是可以采取工厂模式,主要是将原来简单工厂类的逻辑判断分离出来,将它作为一个借口,与 ...
- Monkey Patch/Monkey Testing/Duck Typing/Duck Test
Monkey Patch Monkey Testing Duck Typing Duck Test
- 让linux开机默认开启小键盘
linux默认开机不开启数字键盘numberlock,每次输入开机密码还得劳烦自己去点亮指示灯,让此灯开机自动点亮,需要一个软件才行,就是numlockx了,可以通过yum安装:yuminstall ...
- FunDA(0)- Functional Data Access accessible to all
大数据.多核CPU驱动了函数式编程模式的兴起.因为函数式编程更适合多线程.复杂.安全的大型软件编程.但是,对许多有应用软件开发经验的编程者来说,函数式编程模式是一种全新的.甚至抽象的概念,可能需要很长 ...
- 如何写出安全的API接口(参数加密+超时处理+私钥验证+Https)- 续(附demo)
上篇文章说到接口安全的设计思路,如果没有看到上篇博客,建议看完再来看这个. 通过园友们的讨论,以及我自己查了些资料,然后对接口安全做一个相对完善的总结,承诺给大家写个demo,今天一并放出. 对于安全 ...
- MySQL数据库不能远程访问的解决办法
MySQL数据库不允许从远程访问怎么办? 下面提供两种方法: 1.改表法 MySQL的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入mysql后,更改 ...
- css图片精灵
<ul> <li class="top"> <em>01</em> <p><a href="http:/ ...
- mui 手势事件配置
在开发中监听双击屏幕事件时不起作用,需要在mui.init方法的gestureConfig参数中设置需要监听的手势事件 手势事件配置: 根据使用频率,mui默认会监听部分手势事件,如点击.滑动事件:为 ...