网上二级(多级)联动的例子也不少,有各种不同的操作方法。
我所采用的方法网上也应该有的,不过我还没有看到过。
希望发布到首页能有它的价值所在。好了,开始吧
表结构
二级或多级联动主要是以数据库中具有父编号的表为基础,这个也不例外
id,parent_id,name 三列。
采用js操作
先说下数据在js中的存储方式。
主要用二维数组来存储数据。结构如下:
a[父编号]=[[子编号1,子名称1],[子编号2,子名称2],[子编号3,子名称3],……];
首先用父编号获取所有的子数据,在把子数据的编号及名称绑定在dropdown中
第一步 二级联动数据(后面说这些数据怎么得到)
代码
var cities
=
new
Array();
cities[ ' 00000000-0000-0000-0000-000000000000 ' ] = [[ ' 028db215-8bd7-45ab-bbaa-1efa175c35ca ' , ' 长春 ' ],[ ' bcb32195-2a46-4cd1-9472-6383e8fa55cc ' , ' 沈阳 ' ]];
var schools = new Array();
schools[ ' 028db215-8bd7-45ab-bbaa-1efa175c35ca ' ] = [[ ' 5f22403a-7a59-4b7f-b62d-9451298cbd00 ' , ' 长春1 ' ],[ ' e8f0f665-9a9a-4c44-83fd-598e8a28dcd7 ' , ' 长春2 ' ]];
schools[ ' bcb32195-2a46-4cd1-9472-6383e8fa55cc ' ] = [[ ' 4a743dbf-1fdc-4907-a44e-8d169d715664 ' , ' 沈阳1 ' ]];
cities[ ' 00000000-0000-0000-0000-000000000000 ' ] = [[ ' 028db215-8bd7-45ab-bbaa-1efa175c35ca ' , ' 长春 ' ],[ ' bcb32195-2a46-4cd1-9472-6383e8fa55cc ' , ' 沈阳 ' ]];
var schools = new Array();
schools[ ' 028db215-8bd7-45ab-bbaa-1efa175c35ca ' ] = [[ ' 5f22403a-7a59-4b7f-b62d-9451298cbd00 ' , ' 长春1 ' ],[ ' e8f0f665-9a9a-4c44-83fd-598e8a28dcd7 ' , ' 长春2 ' ]];
schools[ ' bcb32195-2a46-4cd1-9472-6383e8fa55cc ' ] = [[ ' 4a743dbf-1fdc-4907-a44e-8d169d715664 ' , ' 沈阳1 ' ]];
第一级为城市数据,第二级为学校数据。
第二步 设置数据在dropdown中显示
代码
//
根据父编号获取相应的子数据,并显示在obj控件中
// type=0 城市,1学校
// pid 父编号
// obj 要显示数据的dropdown
function SetRegions(type,pid,obj)
{
var text = " <option value='00000000-0000-0000-0000-000000000001'>请选择</option> " ;
var tempArray = new Array();
if (type == 0 ){
tempArray = cities[pid];
} else if (type == 1 ){
tempArray = schools[pid];;
}
if (tempArray != null )
{
for (var i = 0 ;i < tempArray.length;i ++ ){
text += " <option value=' " + tempArray[i][ 0 ] + " '> " + tempArray[i][ 1 ] + " </option> " ;
}
}
$(obj).html(text);
}
// type=0 城市,1学校
// pid 父编号
// obj 要显示数据的dropdown
function SetRegions(type,pid,obj)
{
var text = " <option value='00000000-0000-0000-0000-000000000001'>请选择</option> " ;
var tempArray = new Array();
if (type == 0 ){
tempArray = cities[pid];
} else if (type == 1 ){
tempArray = schools[pid];;
}
if (tempArray != null )
{
for (var i = 0 ;i < tempArray.length;i ++ ){
text += " <option value=' " + tempArray[i][ 0 ] + " '> " + tempArray[i][ 1 ] + " </option> " ;
}
}
$(obj).html(text);
}
第三步 城市改变的时候 选择学校数据
//
用城市编号设置学校子数据
function CityChanged(){
SetRegions ( 1 ,$( " #cities " ).val(), " #schools " );
}
function CityChanged(){
SetRegions ( 1 ,$( " #cities " ).val(), " #schools " );
}
第四步 当然在修改的时候需要进行初始化,这也是以前我最头疼的问题
代码
//
初始化 城市 学校值
// cityId 城市编号
// schoolId 学校编号
function InitRegions(cityId,schoolId)
{
// 初始化城市数据
// SetRegions(0,"00000000-0000-0000-0000-000000000000","#cities");
// 查找城市并设为默认值
$( " #cities option[value= " + cityId + " ] " ).attr( " selected " , " selected " );
if (schoolId != " 00000000-0000-0000-0000-000000000001 " ){
// 初始化学校数据
SetRegions( 1 ,cityId, " #schools " );
// 查找学校并设为默认值
$( " #schools option[value= " + schoolId + " ] " ).attr( " selected " , " selected " );
}
}
// cityId 城市编号
// schoolId 学校编号
function InitRegions(cityId,schoolId)
{
// 初始化城市数据
// SetRegions(0,"00000000-0000-0000-0000-000000000000","#cities");
// 查找城市并设为默认值
$( " #cities option[value= " + cityId + " ] " ).attr( " selected " , " selected " );
if (schoolId != " 00000000-0000-0000-0000-000000000001 " ){
// 初始化学校数据
SetRegions( 1 ,cityId, " #schools " );
// 查找学校并设为默认值
$( " #schools option[value= " + schoolId + " ] " ).attr( " selected " , " selected " );
}
}