js实现的下拉框二级联动效果


Posted in Javascript onApril 30, 2016

本文实例讲述了js实现的下拉框二级联动效果。分享给大家供大家参考,具体如下:

<script language="JavaScript" type="text/javascript">
<!--
/*
 * 说明:将指定下拉列表的选项值清空
 * 转自:Gdong Elvis ( http://www.gdcool.net )
 *
 * @param {String || Object]} selectObj 目标下拉选框的名称或对象,必须
 */
 function removeOptions(selectObj)
 {
 if (typeof selectObj != 'object')
 {
 selectObj = document.getElementById(selectObj);
 }
 // 原有选项计数
 var len = selectObj.options.length;
 for (var i=0; i < len; i++) {
 // 移除当前选项
 selectObj.options[0] = null;
 }
 }
 /*
 * @param {String || Object]} selectObj 目标下拉选框的名称或对象,必须
 * @param {Array} optionList 选项值设置 格式:[{txt:'北京', val:'010'}, {txt:'上海', val:'020'}] ,必须
 * @param {String} firstOption 第一个选项值,如:“请选择”,可选,值为空
 * @param {String} selected 默认选中值,可选
 */
 function setSelectOption(selectObj, optionList, firstOption, selected) {
 if (typeof selectObj != 'object')
 {
 selectObj = document.getElementById(selectObj);
 }
 // 清空选项
 removeOptions(selectObj);
 // 选项计数
 var start = 0;
 // 如果需要添加第一个选项
 if (firstOption) {
 selectObj.options[0] = new Option(firstOption, '');
 // 选项计数从 1 开始
 start ++;
 }
 var len = optionList.length;
 for (var i=0; i < len; i++) {
 // 设置 option
 selectObj.options[start] = new Option(optionList[i].txt, optionList[i].val);
 // 选中项
 if(selected == optionList[i].val)  {
 selectObj.options[start].selected = true;
 }
 // 计数加 1
 start ++;
 }
 }
 //-->
</script>
<script language="JavaScript" type="text/javascript">
var cityArr = [];
cityArr['江苏省'] =
[
 {txt:'南京', val:'南京'},
 {txt:'无锡', val:'无锡'},
 {txt:'徐州', val:'徐州'},
 {txt:'苏州', val:'苏州'},
 {txt:'南通', val:'南通'},
 {txt:'淮阴', val:'淮阴'},
 {txt:'扬州', val:'扬州'},
 {txt:'镇江', val:'镇江'},
 {txt:'常州', val:'常州'}
 ];
cityArr['浙江省'] =
[
 {txt:'杭州', val:'杭州'},
 {txt:'宁波', val:'宁波'},
 {txt:'温州', val:'温州'},
 {txt:'湖州', val:'湖州'}
 ];
function setCity(province)
{
 setSelectOption('city', cityArr[province], '-请选择-');
}
</script>
 <select name="province" id="province" onchange="if(this.value != '') setCity(this.options[this.selectedIndex].value);">
 <option value="">-请选择-</option>
 <option value="江苏省">江苏省</option>
 <option value="浙江省">浙江省</option>
 </select>
 省
 <select name="city" id="city">
 <option value="">-请选择-</option>
 </select>
 市
Javascript 相关文章推荐
Javascript异步表单提交,图片上传,兼容异步模拟ajax技术
May 10 Javascript
基于jquery实现的鼠标拖拽元素复制并写入效果
Aug 23 Javascript
解释&amp;&amp;和||在javascript中的另类用法
Jul 28 Javascript
一款基jquery超炫的动画导航菜单可响应单击事件
Nov 02 Javascript
BootStrap中Datetimepicker和uploadify插件应用实例小结
May 26 Javascript
利用jquery获取select下拉框的值
Nov 23 Javascript
微信小程序 获取当前地理位置和经纬度实例代码
Dec 05 Javascript
jQuery插件ajaxFileUpload使用详解
Jan 10 Javascript
JavaScript实现网页头部进度条刷新
Apr 16 Javascript
Vue.js实现一个todo-list的上移下移删除功能
Jun 26 Javascript
node中Express 动态设置端口的方法
Aug 04 Javascript
js笔试题-接收get请求参数
Jun 15 Javascript
js实现精确到秒的日期选择器完整实例
Apr 30 #Javascript
js简单倒计时实现代码
Apr 30 #Javascript
一个用jquery写的判断div滚动条到底部的方法【推荐】
Apr 29 #Javascript
浅析jquery如何判断滚动条滚到页面底部并执行事件
Apr 29 #Javascript
jQuery中数据缓存$.data的用法及源码完全解析
Apr 29 #Javascript
浅析Javascript中bind()方法的使用与实现
Apr 29 #Javascript
深入剖析JavaScript中的函数currying柯里化
Apr 29 #Javascript
You might like
使用 PHPStorm 开发 Laravel
2015/03/24 PHP
PHP定时任务获取微信access_token的方法
2016/10/10 PHP
PHP设计模式之单例模式原理与实现方法分析
2018/04/25 PHP
Yii2框架自定义验证规则操作示例
2019/02/08 PHP
TP5框架简单登录功能实现方法示例
2019/10/31 PHP
Laravel Eloquent分表方法并使用模型关联的实现
2019/11/25 PHP
使弱类型的语言JavaScript变强势
2009/06/22 Javascript
validator验证控件使用代码
2010/11/23 Javascript
js将long日期格式转换为标准日期格式实现思路
2013/04/07 Javascript
js为数字添加逗号并格式化数字的代码
2013/08/23 Javascript
深入理解JQuery keyUp和keyDown的区别
2013/12/12 Javascript
jquery 重写 ajax提交并判断权限后 使用load方法报错解决方法
2016/01/19 Javascript
JS获取一个未知DIV高度的方法
2016/08/09 Javascript
jQuery图片轮播实现并封装(一)
2016/12/03 Javascript
微信小程序 图片上传实例详解
2017/05/05 Javascript
微信小程序 MinUI组件库系列之badge徽章组件示例
2018/08/20 Javascript
jQuery实现的淡入淡出图片轮播效果示例
2018/08/29 jQuery
小程序实现抽奖动画
2020/04/16 Javascript
jQuery中使用validate插件校验表单功能
2019/05/24 jQuery
Element InfiniteScroll无限滚动的具体使用方法
2020/07/27 Javascript
Python中你应该知道的一些内置函数
2017/03/31 Python
使用python快速在局域网内搭建http传输文件服务的方法
2019/11/14 Python
python给指定csv表格中的联系人群发邮件(带附件的邮件)
2019/12/31 Python
在django admin详情表单显示中添加自定义控件的实现
2020/03/11 Python
python生成xml时规定dtd实例方法
2020/09/21 Python
Rhone官方网站:男士运动服装、健身服装和高级运动服
2019/05/01 全球购物
remote接口和home接口主要作用
2013/05/15 面试题
英语专业推荐信
2013/11/16 职场文书
专科文秘应届生求职信
2013/11/18 职场文书
会计实习生自我鉴定
2013/12/12 职场文书
学校宣传标语
2014/06/18 职场文书
办护照工作证明
2014/10/01 职场文书
2014年监理个人工作总结
2014/12/11 职场文书
三好学生事迹材料
2014/12/24 职场文书
SpringBoot集成Redis的思路详解
2021/10/16 Redis