也谈js操作二级联动

网上二级(多级)联动的例子也不少,有各种不同的操作方法。

我所采用的方法网上也应该有的,不过我还没有看到过。

希望发布到首页能有它的价值所在。好了,开始吧

 

表结构

二级或多级联动主要是以数据库中具有父编号的表为基础,这个也不例外

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 ' ]];

 

第一级为城市数据,第二级为学校数据。

第二步 设置数据在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);
}

 

 

第三步 城市改变的时候 选择学校数据

 

// 用城市编号设置学校子数据
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 " );   
    }
    
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值