HTML学习15 js 三级联动

8 篇文章 0 订阅

三级联动

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		省:<br>
		<select name="sheng" id="sheng">
			<option value="">请选择</option>
		</select>
		<br>
		市:<br>
		<select name="shi" id="shi">
			<option value="">请选择</option>
		</select>
		<br>
		区:<br>
		<select name="qu" id="qu">
			<option value="">请选择</option>
		</select>

		<script type="text/javascript">
			onload = function() {
				var json = {
					"北京": [{
						"北京市": ["朝阳", "海定"]
					}],
					"广东": [{
						"广州市": ["越秀", "天河"]
					}, {
						"深圳市": ["罗湖", "福田"]
					}],
					"湖南": [{
						"长沙市": ["长沙", "芙蓉"]
					}, {
						"衡阳市": ["南岳", "衡阳"]
					}]
				};


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


				for (var i in json) { //使用for  in 迭代对象,变量i就是key
					/* 	console.log(i); */
					var shengOpt = document.createElement("option");

					var shengtxt = document.createTextNode(i);
					shengOpt.appendChild(shengtxt);
					shengOpt.value = i;
					sheng.appendChild(shengOpt);
				}


				sheng.onchange = function(event) {
					/* console.log(1); */
					/* console.log(sheng.value); */
					//又要解析json
		
					var shiArray = json[sheng.value];
					console.log(shiArray);
					var shi = document.getElementById("shi");
					//在追加之前清空选项内容
					shi.innerHTML = "";
					//添加请选择
					var shiOpt = document.createElement("option");
					var shiOptTxt = document.createTextNode("请选择");
					shiOpt.appendChild(shiOptTxt);
					shi.appendChild(shiOpt);

					for (let s of shiArray) {
						for (var i in s) {
							/* console.log(i); */
							var shiOpt = document.createElement("option");
							var shiOptTxt = document.createTextNode(i);
							shiOpt.appendChild(shiOptTxt);
							shiOpt.value = i;
							shi.appendChild(shiOpt);
						}
					}
				}
				
				
				var shi = document.getElementById("shi");
				shi.onchange = function(){
					console.log(this.value);
					console.log(sheng.value);
					
					var shi = json[sheng.value];
					var qu = document.getElementById("qu");
					
					qu.innerHTML = "";
					//添加请选择
					var quOpt = document.createElement("option");
					var quOptTxt = document.createTextNode("请选择");
					quOpt.appendChild(quOptTxt);
					qu.appendChild(quOpt);
					
					
					for (var item of shi) {
						var quval = item[this.value];
						if(quval){
							for (var item of quval) {
								var quOpt = document.createElement("option");
								var quOptTxt = document.createTextNode(item);
								quOpt.appendChild(quOptTxt);
								quOpt.value = item;
								qu.appendChild(quOpt);
							}
						}
					}
					
				}

			};

			/* 做一个三级联动
			数据是:
			var json = {
						"北京": [{
							"北京市": ["朝阳", "海定"]
						}],
						"广东": [{
							"广州市": ["越秀", "天河"]
						}, {
							"深圳市": ["罗湖", "福田"]
						}],
						"湖南": [{
							"长沙市": ["长沙", "芙蓉"]
						}, {
							"衡阳市": ["南岳", "衡阳"]
						}]
					}; 
			1.js的渲染  select 标签的渲染
			2.json数据的解析
			*/
		</script>
	</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值