js实现二级联动

这个是简单也是最基本的下拉框联动的示例,这个示例主要针对那些只有二级联动,且第一级是固定的选项,第二级的内容也比较简单。这里使用了javascript来联动第二级下拉框。

 

[xhtml]  view plain  copy
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">    
  2. <HTML>    
  3.     <HEAD>    
  4.         <TITLE>New Document</TITLE>  
  5.         <META NAME="Generator" CONTENT="EditPlus">  
  6.         <META NAME="Author" CONTENT="">  
  7.         <META NAME="Keywords" CONTENT="">  
  8.         <META NAME="Description" CONTENT="">  
  9.         <mce:script language="JavaScript" type="text/javascript"><!--  
  10.         //定义了城市的二维数组,里面的顺序跟省份的顺序是相同的。通过selectedIndex获得省份的下标值来得到相应的城市数组    
  11.         var city=[    
  12.             ["北京","天津","上海","重庆"],  
  13.             ["南京","苏州","南通","常州"],  
  14.             ["福州","福安","龙岩","南平"],  
  15.             ["广州","潮阳","潮州","澄海"],  
  16.             ["兰州","白银","定西","敦煌"]  
  17.         ];    
  18.         function getCity(){    
  19.             //获得省份下拉框的对象    
  20.             var sltProvince=document.form1.province;  
  21.             //获得城市下拉框的对象    
  22.             var sltCity=document.form1.city;    
  23.             //得到对应省份的城市数组    
  24.             var provinceCity=city[sltProvince.selectedIndex - 1];    
  25.             //清空城市下拉框,仅留提示选项    
  26.             sltCity.length=1;    
  27.             //将城市数组中的值填充到城市下拉框中    
  28.             for(var i=0;i<provinceCity.length;i++){    
  29.                 sltCity[i+1]=new Option(provinceCity[i],provinceCity[i]);    
  30.                 }    
  31.         }    
  32.           
  33. // --></mce:script>    
  34.     </HEAD>    
  35.     <BODY>    
  36.         <FORM METHOD=POST ACTION="" name="form1">  
  37.             <SELECT NAME="province" onChange="getCity()">  
  38.                 <OPTION VALUE="0">请选择所在省份</OPTION>  
  39.                 <OPTION VALUE="直辖市">直辖市</OPTION>  
  40.                 <OPTION VALUE="江苏省">江苏省</OPTION>  
  41.                 <OPTION VALUE="福建省">福建省</OPTION>  
  42.                 <OPTION VALUE="广东省">广东省</OPTION>    
  43.                 <OPTION VALUE="甘肃省">甘肃省</OPTION>  
  44.             </SELECT>    
  45.             <SELECT NAME="city">    
  46.                 <OPTION VALUE="0">请选择所在城市</OPTION>    
  47.             </SELECT>    
  48.         </FORM>    
  49.     </BODY>    
  50. </HTML>    

 

这段代码比较简单。

如果对js不大熟悉,可以看看下面关于js处理select对象的内容:

1、使用selectedIndex属性获取当前选项的索引
    下拉框的选项是一个线性数组,每个选项都有一个索引,selectedIndex表示当前被选中的选项的索引号。结合options属性,可以得到被选中 的option对象,从而对其做进一步的处理。当下拉框可多选时,selectedIndex属性返回第一个被选中的索引。
    selectedIndex是个只读的属性,想把通过索引指定的下拉框的项设置为选中状态,可以设置option对象的selected=true来实现。

2、为select对象添加一个选项
    sltCity[i + 1 ] = new  Option(provinceCity[i],provinceCity[i]);
    
new  Option(provinceCity[i],provinceCity[i])表示创建一个值为 provinceCity[i],文本为 provinceCity[i]的option对象, sltCity是页面上的city对象, i + 1指定新添选项的位置。

3、清空一个select对象
    要将下拉框的所有选项删除有两种方法,


    第一种方法就是遍历删除:

[javascript]  view plain  copy
  1. var l=myselect.length;    
  2. for(var i=0;i<l;i++){    
  3.     myselect.options[i]=null;    
  4.    

 

第二种方法比较简单,因此一般都使用此方法:

[javascript]  view plain  copy
  1. myselect.length=0;  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
<script type="text/javascript" src="jquery-1.6.4.js"></script> <script type="text/javascript"> try{ var sf=new Array(); sf[0]=new Array("北京市","东城|西城|崇文|宣武|朝阳|丰台|石景山|海淀|门头沟|房山|通州|顺义|昌平|大兴|平谷|怀柔|密云|延庆"); sf[1]=new Array("上海市","黄浦|卢湾|徐汇|长宁|静安|普陀|闸北|虹口|杨浦|闵行|宝山|嘉定|浦东|金山|松江|青浦|南汇|奉贤|崇明"); sf[2] = new Array("天津市","和平|东丽|河东|西青|河西|津南|南开|北辰|河北|武清|红挢|塘沽|汉沽|大港|宁河|静海|宝坻|蓟县"); sf[3] = new Array("重庆市","万州|涪陵|渝中|大渡口|江北|沙坪坝|九龙坡|南岸|北碚|万盛|双挢|渝北|巴南|黔江|长寿|綦江|潼南|铜梁 |大足|荣昌|壁山|梁平|城口|丰都|垫江|武隆|忠县|开县|云阳|奉节|巫山|巫溪|石柱|秀山|酉阳|彭水|江津|合川|永川|南川"); sf[4] = new Array("河北省","石家庄|邯郸|邢台|保定|张家口|承德|廊坊|唐山|秦皇岛|沧州|衡水"); sf[5] = new Array("山西省","太原|大同|阳泉|长治|晋城|朔州|吕梁|忻州|晋中|临汾|运城"); sf[6] = new Array("内蒙古自治区","呼和浩特|包头|乌海|赤峰|呼伦贝尔盟|阿拉善盟|哲里木盟|兴安盟|乌兰察布盟|锡林郭勒盟|巴彦淖尔盟|伊克昭盟"); sf[7] = new Array("辽宁省","沈阳|大连|鞍山|抚顺|本溪|丹东|锦州|营口|阜新|辽阳|盘锦|铁岭|朝阳|葫芦岛"); sf[8] = new Array("吉林省","长春|吉林|四平|辽源|通化|白山|松原|白城|延边"); sf[9] = new Array("黑龙江省","哈尔滨|齐齐哈尔|牡丹江|佳木斯|大庆|绥化|鹤岗|鸡西|黑河|双鸭山|伊春|七台河|大兴安岭"); sf[10] = new Array("江苏省","南京|镇江|苏州|南通|扬州|盐城|徐州|连云港|常州|无锡|宿迁|泰州|淮安"); sf[11] = new Array("浙江省","杭州|宁波|温州|嘉兴|湖州|绍兴|金华|衢州|舟山|台州|丽水"); sf[12] = new Array("安徽省","合肥|芜湖|蚌埠|马鞍山|淮北|铜陵|安庆|黄山|滁州|宿州|池州|淮南|巢湖|阜阳|六安|宣城|亳州"); sf[13] = new Array("福建省","福州|厦门|莆田|三明|泉州|漳州|南平|龙岩|宁德"); sf[14] = new Array("江西省","南昌市|景德镇|九江|鹰潭|萍乡|新馀|赣州|吉安|宜春|抚州|上饶"); sf[15] = new Array("山东省","济南|青岛|淄博|枣庄|东营|烟台|潍坊|济宁|泰安|威海|日照|莱芜|临沂|德州|聊城|滨州|菏泽"); sf[16] = new Array("河南省","郑州|开封|洛阳|平顶山|安阳|鹤壁|新乡|焦作|濮阳|许昌|漯河|三门峡|南阳|商丘|信阳|周口|驻马店|济源"); sf[17] = new Array("湖北省","武汉|宜昌|荆州|襄樊|黄石|荆门|黄冈|十堰|恩施|潜江|天门|仙桃|随州|咸宁|孝感|鄂州"); sf[18] = new Array("湖南省","长沙|常德|株洲|湘潭|衡阳|岳阳|邵阳|益阳|娄底|怀化|郴州|永州|湘西|张家界"); sf[19] = new Array("广东省","广州|深圳|珠海|汕头|东莞|中山|佛山|韶关|江门|湛江|茂名|肇庆|惠州|梅州|汕尾|河源|阳江|清远|潮州|揭阳|云浮"); sf[20] = new Array("广西壮族自治区","南宁|柳州|桂林|梧州|北海|防城港|钦州|贵港|玉林|南宁地区|柳州地区|贺州|百色|河池"); sf[21] = new Array("海南省","海口|三亚"); sf[22] = new Array("四川省","成都|绵阳|德阳|自贡|攀枝花|广元|内江|乐山|南充|宜宾|广安|达川|雅安|眉山|甘孜|凉山|泸州"); sf[23] = new Array("贵州省","贵阳|六盘水|遵义|安顺|铜仁|黔西南|毕节|黔东南|黔南"); sf[24] = new Array("云南省","昆明|大理|曲靖|玉溪|昭通|楚雄|红河|文山|思茅|西双版纳|保山|德宏|丽江|怒江|迪庆|临沧"); sf[25] = new Array("西藏自治区","拉萨|日喀则|山南|林芝|昌都|阿里|那曲"); sf[26] = new Array("陕西省","西安|宝鸡|咸阳|铜川|渭南|延安|榆林|汉中|安康|商洛"); sf[27] = new Array("甘肃省","兰州|嘉峪关|金昌|白银|天水|酒泉|张掖|武威|定西|陇南|平凉|庆阳|临夏|甘南"); sf[28] = new Array("宁夏回族自治区","银川|石嘴山|吴忠|固原"); sf[29] = new Array("青海省","西宁|海东|海南|海北|黄南|玉树|果洛|海西"); sf[30] = new Array("新疆维吾尔族自治区","乌鲁木齐|石河子|克拉玛依|伊犁|巴音郭勒|昌吉|克孜勒苏柯尔克孜|博尔塔拉|吐鲁番|哈密|喀什|和田|阿克苏"); sf[31] = new Array("香港特别行政区","香港特别行政区"); sf[32] = new Array("澳门特别行政区","澳门特别行政区"); sf[33] = new Array("台湾省","台北|高雄|台中|台南|屏东|南投|云林|新竹|彰化|苗栗|嘉义|花莲|桃园|宜兰|基隆|台东|金门|马祖|澎湖"); sf[34] = new Array("其它","北美洲|南美洲|亚洲|非洲|欧洲|大洋洲"); }catch(e){ alert(e); } $(document).ready(function(e) { $("#pro").change(function(){ try{ var pro=$(this).val(); var i,j,tmpcity=new Array(); for(i=0;i<sf.length;i++){ if(pro==sf[i][0].toString()){ tmpcity=sf[i][1].split("|"); $("#city").html(""); for(j=0;j<tmpcity.length;j++){ $("#city").append("<option>"+tmpcity[j]+"</option>"); } } } }catch(e){ alert(e); } }); }); </script>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值