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 ...
随机推荐
- [Tool] Open Live Writer插件开发
一 前言 Windows Live Writer(简称 WLW)开源之后变成 Open Live Writer(简称 OLW),原先 WLW 的插件在 OLW 下都不能用了,原因很简单,WLW 插件开 ...
- VS2012程序打包部署详解
VS2012没有自带打包工具,所以要先下载并安装一个打包工具.我采用微软提供的打包工具: InstallShield2015LimitedEdition.下载地址:https://msdn.micr ...
- bzoj3388(神奇的解法)
题目大意: 约翰的表哥罗恩生活在科罗拉多州.他近来打算教他的奶牛们滑雪,但是奶牛们非常害羞,不敢在游人如织的度假胜地滑雪.没办法,他只好自己建滑雪场了.罗恩的雪场可以划分为W列L行(1≤W≤500;1 ...
- 深度理解CSS样式表,内有彩蛋....
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- FunDA(2)- Streaming Data Operation:流式数据操作
在上一集的讨论里我们介绍并实现了强类型返回结果行.使用强类型主要的目的是当我们把后端数据库SQL批次操作搬到内存里转变成数据流式按行操作时能更方便.准确.高效地选定数据字段.在上集讨论示范里我们用集合 ...
- 关于linux下crontab的使用
minute hour day month dayofweek command minute - 从0到59的整数 hour - 从0到23的整数 day - 从1到31的 ...
- 让产品有效迭代,前端A/B Testing的简单实现
A/B Testing简介 互联网产品的迭代速度很快,往往一周一小发布,一月一大发布,产品提出的种种需求,哪些改动是提升产品体验的,哪些是阻碍产品进步的,如果没有数据可以参考,仅仅是靠拍脑袋的话,对产 ...
- SVG Path高级教程
课程分为四个方面: 1. Path概述 2. 移动和直线命令 3. 弧线命令 4. 贝塞尔曲线命令 Path概述 <path> 标签用来定义路径,Path字符串是由命令及其参数组组成的字符 ...
- React Native 之TabBarIOS
前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...
- ViewPager与Tab结合使用
我们有时候需要 标题页卡与ViewPager结合使用,其实原理也很简单. 不过工程中要引入android-support-design.jar 首先是布局文件 <android.support. ...