也谈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、付费专栏及课程。

余额充值