<!DOCTYPE html>

<html>

<head lang="en">

<meta charset="UTF-8">

<title>三级联动</title>

</head>

<body>

<select id="sheng">

<option value="">-请选择-</option><!--先创建三个下拉栏,分别对应 省 市 县-->

</select>

<select id="shi">

<option value="">-请选择-</option>

</select>

<select id="xian">

<option value="">-请选择-</option>

</select>

<script>

var osheng=document.getElementById("sheng");

var oshi=document.getElementById("shi");

var oxian=document.getElementById("xian");

var arr_sheng=["陕西省","云南省","四川省","山西省"];<!--创建一个一维数组,存入省的值-->

var arr_shi=[<!--创建一个二维数组,最外层每一个元素对应省-->

["西安市","咸阳市","宝鸡市","渭南市"],<!--数组中的第一个元素内又定义一个数组存的市的值-->

["昆明市","大理市","丽江市","西双版纳市"],

["乐山市","成都市","大同市","高新市"],

["太原市","屏显市","乐宝市","李伟市"]

];

var arr_xian=[<!--创建一个三维数组,最外层每一个元素(对应省)-->

[<!--数组中定义四个数组(对应市)-->

["西安县1","西安县2"],["咸阳市1","咸阳市2"],["宝鸡市1","宝鸡市2"],["渭南市1","渭南市2"]

],<!--数组中定义两个元素(对应县)-->

[

["昆明市1","昆明市2"],["大理市1","大理市2"],["丽江市1","丽江市2"],["西双版纳市1","西双版纳市2"]

],

[

["乐山市1","乐山市2"],["成都市1","成都市2"],["大同市1","大同市2"],["高新市1","高新市2"]

],

[

["太原市1","太原市2"],["屏显市1","屏显市2"],["乐宝市1","乐宝市2"],["李伟市1","李伟市2"]

]

];

var  quanju_arr;//创建一个全局对象,用于存储一个中间数组

function input_arr(arr,event){//封装一个函数,用于向下拉栏中添加元素

for(var i=0;i<arr.length;i++){//下拉栏内的元素来源于数组中的元素,遍历数组

var option=new Option(arr[i],i);//创建Option对象(这个O要大写),存入值

event.appendChild(option);//把option添加到event对象的末尾

}

}

input_arr(arr_sheng,osheng);//调用,给省下拉栏添元素

osheng.onchange= function () {//给下拉栏绑定事件(当下拉栏元素改变时执行)

oshi.options.length=1;//当省下拉栏改变时,清空市的下拉栏内元素

oxian.options.length=1;//当省下拉栏改变时,清空县的下拉栏内元素

var index=this.value;//每一个option标签都有一个value值索引,获取索引,用于数组中元素的选择

var arr_shi_next=arr_shi[index];//获取当前选择省的市元素并赋给一个数组

quanju_arr=arr_xian[index];//获取当前选择省中市的县元素并赋给定义的中间数组

input_arr(arr_shi_next,oshi);//调用,给市下拉栏添元素

}

oshi.onchange= function () {

oxian.options.length=1;

var index=this.value;

var arr_xian_next=quanju_arr[index];

input_arr(arr_xian_next,oxian);//调用,给县下拉栏添元素

}

</script>

</body>

</html>

js总结:三级联动的更多相关文章

  1. QQ JS省市区三级联动

    如下图: 首先写一个静态的页面: <!DOCTYPE html> <html> <head> <title>QQ JS省市区三级联动</title ...

  2. 从QQ网站中提取的纯JS省市区三级联动

    在 http://ip.qq.com/ 的网站中有QQ自己的JS省市区三级联动 QQ是使用引用外部JS来实现三级联动的.JS如下:http://ip.qq.com/js/geo.js <!DOC ...

  3. JS年月日三级联动下拉框日期选择代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. 原生JS实现三级联动

    代码实现 <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF- ...

  5. MVC图片上传详解 IIS (安装SSL证书后) 实现 HTTP 自动跳转到 HTTPS C#中Enum用法小结 表达式目录树 “村长”教你测试用例 引用provinces.js的三级联动

    MVC图片上传详解   MVC图片上传--控制器方法 新建一个控制器命名为File,定义一个Img方法 [HttpPost]public ActionResult Img(HttpPostedFile ...

  6. JS 省市区三级联动

    JS 省市区三级联动: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...

  7. JS省市区三级联动

    不需要访问后台服务器端,不使用Ajax,无刷新,纯JS实现的省市区三级联动. 当省市区数据变动是只需调正js即可. 使用方法: <!DOCTYPE html><html>< ...

  8. 插件 原生js 省市区 三级联动 源码

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 使用腾讯IP分享计划网站中的纯JS省市区三级联动

    JS地址:http://ip.qq.com/js/geo.js 实例如下: <!DOCTYPE html> <html> <head> <title>省 ...

  10. 引用provinces.js的三级联动

    第一次写随笔   应该写的不是太好   请多多见谅 我这次是在网上发现了一个三级联动    也是给新人一个福利 这个是你需要新建个 JavaScript 文件  并复制到你新建的文件里面 var pr ...

随机推荐

  1. win10同时安装 office2016和visio2016

    一.下载镜像文件 因为office 2016和 visio2016 镜像文件是一样的,只是名称不一样,所以只需要下载一个即可. 二.下载Office 2016 Deployment Tool工具 到微 ...

  2. 【PAT】B1004 成绩排名

    简单题 循环输入放入结构体数组,一个sort搞定 #include <stdio.h> #include<algorithm> using namespace std; str ...

  3. 数据结构【查找】—平衡二叉树AVL

    /*自己看了半天也没看懂代码,下次再补充说明*/ 解释: 平衡二叉树(Self-Balancing Binary Search Tree 或Height-Balanced Binary Search ...

  4. 【Linux基础】crontab定时命令详解

    周期执行的任务一般由cron这个守护进程来处理[ps -ef|grep cron].cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间.cron的配置文件称为“crontab”,是 ...

  5. Spring中事务配置以及事务不起作用可能出现的问题

    前言:在Spring中可以通过对方法进行事务的配置,而不是像原来通过手动写代码的方式实现事务的操作,这在很大程度上减少了开发的难度,本文介绍Spring事务配置的两种方式:基于配置文件的方式和基于注解 ...

  6. Python 中两个字典(dict)合并

    dict1 = { "name":"owen", "age": 18 } dict2 = { "birthday": & ...

  7. java读取properties中文乱码

    1 确认properties文件的编码是utf-8 2 采用流的方式读取文件,设置编码为utf-8 public class ErrorCodeConfig { static Properties p ...

  8. oracle 多版本

    并发控制 concurrency control 数据库提供的函数集合,允许多个人同时访问和修改数据. 锁(lock)是Oracle管理共享数据库资源并发访问并防止并发数据库事务之间“相互干涉”的核心 ...

  9. Md5的生成

    1.使用hashlib包(一) import hashlib src = 'anthing' m1 = hash.new() m1.update(src) print (m1.hexdigest()) ...

  10. iptables 从一台机到另一台机端口转发

    启用网卡转发功能#echo 1 > /proc/sys/net/ipv4/ip_forward 举例:从192.168.0.132:21521(新端口)访问192.168.0.211:1521端 ...