用 jsp 写的 ajax 技术实现省市县等 n 级联动

2024-06-23 12:18

本文主要是介绍用 jsp 写的 ajax 技术实现省市县等 n 级联动,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考网上一些例子,以及看的一些视频,使用 ajax 技术写的第一个实例。

功能要求:选择省,出现相应的市;再选择市,出现相应的学校……(PS.  不管多少级联动 , 明白第一级联动的原理后,后面的 n 级联动都是一样的)


前端JSP:

		<div class="right"><h3>请输入教师信息:</h3><form action="LogingTeacher" enctype="multipart/form-data" method="post" ><span style="white-space:pre">		</span>// 提交到 LoginSerletTeacher.java 程序中<ul><li>省份:<select id="province" name="province" οnchange="getCities(province,city)"><option value="">--省--</option><%for(int j = 0; j < list.size(); j ++){Province province = (Province)list.get(j) ;%><option value="<%=province.getId()%>"><%=province.getName()%></option><%}%></select></li><li>市:<select id="city" name="city" οnchange="getSchools(city,school)"><option value="">--市--</option></select></li><li>学校:<select id="school" name="school" οnchange="getColleges(school,collegeid)"><option value="">--学校--</option></select></li><li>学院:<select id="collegeid" name="collegeid"><option value="">--学院--</option></select></li><li>姓名:<input type="text" name="teacherName"/></li><li>性别:	<input type="radio" value="1" name="sex" checked="checked" /> 男<input type="radio" value="2" name="sex" /> 女<input type="radio" value="3" name="sex" /> 保密</li><li>头像:	<input type="file" name="userHead" /></li><li>职称:	<input type="radio" name="title" value="1" /> 院士<input type="radio" name="title" value="2" /> 教授<input type="radio" name="title" value="3" /> 副教授<input type="radio" name="title" value="4" /> 讲师	</li><li> 简介:  <br /><textarea cols="50" rows="12"></textarea></li><input type="submit" value="提交" class="submit" /></ul></form></div>
js函数:(一级联动和其它所有联动都一样的)
var myXmlHttpRequest = getXmlHttpObject() ;
function getCities(parent,obj) {var data = parent.value ;myXmlHttpRequest.open("GET", "CitiesListServlet?provinceId="+data, false) ;// 使用 get 方法,将 provinceId 的值传到 CitiesListServlet.java <span style="white-space:pre">								</span>   // 然后进行对数据的读取 , 这个很简单就不贴代码了 myXmlHttpRequest.onreadystatechange = function(){chuli(obj) ;}myXmlHttpRequest.send(null) ;}// 获取 ajax 引擎
function getXmlHttpObject() {var xmlHttpRequest = false ;if(window.XMLHttpRequest){xmlHttpRequest = new XMLHttpRequest() ;if(xmlHttpRequest.overrideMimeType){xmlHttpRequest.overrideMimeType("text/xml") ;}}else {if(window.ActiveXObject){try{xmlHttpRequest = new ActiveXObject("Msxml2.XMLHTTP") ;}catch(e) {try{xmlHttpRequest = new ActiveXObject("Microsoft.XMLHTTP") ; }catch(e){}}}}return xmlHttpRequest ;
}function chuli(obj) {if(myXmlHttpRequest.readyState == 4) {if(myXmlHttpRequest.status == 200){//window.alert(myXmlHttpRequest.responseXML) ;var xmlDoc = myXmlHttpRequest.responseXML.documentElement ;		// 获得返回的 xml 文档var xSel = xmlDoc.getElementsByTagName('select') ;	// 获得 xml 文档中所有的 <select> 标记var select_root = document.getElementById(obj.id) ;	// 获得网页中的第二个下拉框select_root.options.length = 0 ;		// 长度清零// 添加 " --市-- "var cityOption = document.createElement("option") ;cityOption.innerText = "--市--" ;		select_root.appendChild(cityOption) ;for(var i = 0; i < xSel.length; i ++) {var xValue = xSel[i].childNodes[0].firstChild.nodeValue;  var xText = xSel[i].childNodes[1].firstChild.nodeValue ;var option = new Option(xText, xValue) ;try{select_root.add(option) ;<span style="white-space:pre">	</span>// 将获取到的 option 值赋给 select }catch(e){}}// 排序sortOptions(select_root) ;<span style="white-space:pre">		</span>// sortOptions() 对select 中的所有的Option进行排序
<span style="white-space:pre">								</span>// 有关 sortOptions() 的写法,参照我写的另一篇文章}else {alert("不能得到市信息"+req.statusText) ;}}
}

这篇关于用 jsp 写的 ajax 技术实现省市县等 n 级联动的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1087137

相关文章

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

乐鑫 Matter 技术体验日|快速落地 Matter 产品,引领智能家居生态新发展

随着 Matter 协议的推广和普及,智能家居行业正迎来新的发展机遇,众多厂商纷纷投身于 Matter 产品的研发与验证。然而,开发者普遍面临技术门槛高、认证流程繁琐、生产管理复杂等诸多挑战。  乐鑫信息科技 (688018.SH) 凭借深厚的研发实力与行业洞察力,推出了全面的 Matter 解决方案,包含基于乐鑫 SoC 的 Matter 硬件平台、基于开源 ESP-Matter SDK 的一

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

持久层 技术选型如何决策?JPA,Hibernate,ibatis(mybatis)

转自:http://t.51jdy.cn/thread-259-1-1.html 持久层 是一个项目 后台 最重要的部分。他直接 决定了 数据读写的性能,业务编写的复杂度,数据结构(对象结构)等问题。 因此 架构师在考虑 使用那个持久层框架的时候 要考虑清楚。 选择的 标准: 1,项目的场景。 2,团队的技能掌握情况。 3,开发周期(开发效率)。 传统的 业务系统,通常业

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为

亮相WOT全球技术创新大会,揭秘火山引擎边缘容器技术在泛CDN场景的应用与实践

2024年6月21日-22日,51CTO“WOT全球技术创新大会2024”在北京举办。火山引擎边缘计算架构师李志明受邀参与,以“边缘容器技术在泛CDN场景的应用和实践”为主题,与多位行业资深专家,共同探讨泛CDN行业技术架构以及云原生与边缘计算的发展和展望。 火山引擎边缘计算架构师李志明表示:为更好地解决传统泛CDN类业务运行中的问题,火山引擎边缘容器团队参考行业做法,结合实践经验,打造火山

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页: