原生js封装二级城市下拉列表的实现代码


Posted in Javascript onJune 16, 2016

闲的蛋疼,封装了个二级城市下拉 先保证html里有

<SPAN style="BACKGROUND-COLOR: #ffffff; COLOR: #ff0000"><select id="province" size=1 > 
</select> 
<select id="city" style="width:60px"> 
</select> 
<input type="hidden" id="pro_city" /></SPAN>

然后引用js  最终通过new SelectCity()  调用。  懒得分离这里js就写在页面了

一言不合上代码

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

以上就是小编为大家带来的原生js封装二级城市下拉列表的实现代码的全部内容了,希望大家多多支持脚步之家。

Javascript 相关文章推荐
关于JS控制代码暂停的实现方法分享
Oct 11 Javascript
借助script进行Http跨域请求:JSONP实现原理及代码
Mar 19 Javascript
jquery对table中各数据的增加、保存、删除操作示例
May 14 Javascript
node.js 开发指南 ? Node.js 连接 MySQL 并进行数据库操作
Jul 29 Javascript
jquery中checkbox全选失效的解决方法
Dec 26 Javascript
分享10个原生JavaScript技巧
Apr 20 Javascript
js强制把网址设为默认首页
Sep 29 Javascript
JS全角与半角转化实例(分享)
Jul 04 Javascript
Vue.directive使用注意(小结)
Aug 31 Javascript
elementUI Vue 单个按钮显示和隐藏的变换功能(两种方法)
Sep 04 Javascript
详解JavaScript之ES5的继承
Jul 08 Javascript
javascript读取本地文件和目录方法详解
Aug 06 Javascript
jQuery获取剪贴板内容的方法
Jun 16 #Javascript
javascript作用域、作用域链(菜鸟必看)
Jun 16 #Javascript
全面理解JavaScript中的继承(必看)
Jun 16 #Javascript
深入浅析JS的数组遍历方法(推荐)
Jun 15 #Javascript
JavaScript对象数组排序实例方法浅析
Jun 15 #Javascript
JavaScript实现点击文本自动定位到下拉框选中操作
Jun 15 #Javascript
JavaScript对象数组如何按指定属性和排序方向进行排序
Jun 15 #Javascript
You might like
Session保存到数据库的php类分享
2011/10/24 PHP
PHP中使用asort进行中文排序失效的问题处理
2014/08/18 PHP
PHP中使用curl伪造IP的简单方法
2015/08/07 PHP
Laravel Intervention/image图片处理扩展包的安装、使用与可能遇到的坑详解
2017/11/14 PHP
PHP命名空间用法实例分析
2019/09/04 PHP
document.getElementById方法在Firefox与IE中的区别
2010/05/18 Javascript
onkeypress字符按键兼容所有浏览器使用介绍
2013/04/24 Javascript
jquery中focus()函数实现当对象获得焦点后自动把光标移到内容最后
2013/09/29 Javascript
js简单设置与使用cookie的方法
2016/01/22 Javascript
一道常被人轻视的web前端常见面试题(JS)
2016/02/15 Javascript
JavaScript性能优化之函数节流(throttle)与函数去抖(debounce)
2016/08/11 Javascript
javascript实现简单的可随机变色网页计算器示例
2016/12/30 Javascript
js实现手机发送验证码功能
2017/03/13 Javascript
jQuery ajax动态生成table功能示例
2017/06/14 jQuery
AngularJS 多指令Scope问题的解决
2018/10/25 Javascript
小程序实现多列选择器
2019/02/15 Javascript
PHPStorm中如何对nodejs项目进行单元测试详解
2019/02/28 NodeJs
vue使用axios上传文件(FormData)的方法
2019/04/14 Javascript
vue使用高德地图点击下钻上浮效果的实现思路
2019/10/12 Javascript
JavaScript oncopy事件用法实例解析
2020/05/13 Javascript
Vue如何基于es6导入外部js文件
2020/05/15 Javascript
一起深入理解js中的事件对象
2021/02/06 Javascript
[01:23:24]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Elephant BO3 第三场 2月7日
2021/03/11 DOTA
python3.3使用tkinter开发猜数字游戏示例
2014/03/14 Python
Python实现求最大公约数及判断素数的方法
2015/05/26 Python
利用Python开发实现简单的记事本
2016/11/15 Python
Python 字典与字符串的互转实例
2017/01/13 Python
基于Python中单例模式的几种实现方式及优化详解
2018/01/09 Python
Python 开发工具PyCharm安装教程图文详解(新手必看)
2020/02/28 Python
美国最古老的精致书写工具制造商:A.T. Cross(高仕)
2018/01/30 全球购物
大专应届生个人简历的自我评价
2013/10/15 职场文书
企划专员岗位职责
2013/12/09 职场文书
吸烟检讨书2000字
2014/02/13 职场文书
2015年财务部工作总结
2015/04/10 职场文书
泰坦尼克号观后感
2015/06/04 职场文书
MySQL视图概念以及相关应用
2022/04/19 MySQL