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 相关文章推荐
延时重复执行函数 lLoopRun.js
May 08 Javascript
jquery关于图形报表的运用实现代码
Jan 06 Javascript
浅析javascript中function 的 length 属性
May 27 Javascript
jQuery验证插件validation使用指南
Apr 21 Javascript
JQuery查找DOM节点的方法
Jun 11 Javascript
AngularJS实现按钮提示与点击变色效果
Sep 07 Javascript
微信公众平台开发教程(五)详解自定义菜单
Dec 02 Javascript
js正则表达式验证表单【完整版】
Mar 06 Javascript
javascript防篡改对象实例详解
Apr 10 Javascript
[原创]jquery判断元素内容是否为空的方法
May 04 jQuery
vue-cli脚手架build目录下utils.js工具配置文件详解
Sep 14 Javascript
js回调函数仿360开机
Dec 26 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
利用js调用后台php进行数据处理原码
2006/10/09 PHP
PHP中each与list用法分析
2016/01/08 PHP
JavaScript 动态添加表格行 使用模板、标记
2009/10/24 Javascript
使用js解决由border属性引起的div宽度问题
2013/11/26 Javascript
JS实现根据出生年月计算年龄
2014/01/10 Javascript
JS常用函数使用指南
2014/11/23 Javascript
7个让JavaScript变得更好的注意事项
2015/01/28 Javascript
JavaScript数据类型判定的总结笔记
2015/07/31 Javascript
canvas学习之API整理笔记(二)
2016/12/29 Javascript
Node.js中sequelize时区的配置方法
2017/12/10 Javascript
JS实现移动端触屏拖拽功能
2018/07/31 Javascript
详解js访问对象的属性和方法
2018/10/25 Javascript
vue.js实现三级菜单效果
2019/10/19 Javascript
HTML+JS实现“代码雨”效果源码(黑客帝国文字下落效果)
2020/03/17 Javascript
js验证密码强度解析
2020/03/18 Javascript
Vue中关闭弹窗组件时销毁并隐藏操作
2020/09/01 Javascript
Python  连接字符串(join %)
2008/09/06 Python
Python和C/C++交互的几种方法总结
2017/05/11 Python
python实现用户管理系统
2018/01/10 Python
Python使用pickle模块储存对象操作示例
2018/08/15 Python
解决vscode python print 输出窗口中文乱码的问题
2018/12/03 Python
Python + OpenCV 实现LBP特征提取的示例代码
2019/07/11 Python
Python with关键字,上下文管理器,@contextmanager文件操作示例
2019/10/17 Python
python matplotlib imshow热图坐标替换/映射实例
2020/03/14 Python
python实现数学模型(插值、拟合和微分方程)
2020/11/13 Python
python 生成正态分布数据,并绘图和解析
2020/12/21 Python
python中xlrd模块的使用详解
2021/02/01 Python
html5生成柱状图(条形图)效果的实例代码
2016/03/25 HTML / CSS
经济学人订阅:The Economist
2018/07/19 全球购物
一站式跨境收款解决方案:Payoneer(派安盈)
2018/09/06 全球购物
重写子类方法时,抛出异常的书写注意事项
2015/10/17 面试题
铁路安全事故反思
2014/04/26 职场文书
小学优秀学生评语
2014/12/29 职场文书
2015年乡镇卫生院妇幼保健工作总结
2015/05/19 职场文书
抢劫罪辩护词
2015/05/21 职场文书
大学毕业典礼致辞
2015/07/29 职场文书