整个业务的流程:
客户端发送请求 → 业务层取出数据 → Servlet生成DOM树回应客户端 → 客户端接收XML数据 → 进行下拉菜单的动态加载

业务层用来取出所有的省份,通过省份id取出对应的所有城市,其中的操作省略,直接奔正题(原生操作,不使用框架):

show.html(显示页):

<!DOCTYPE html>
<html>
<head>
<Meta charset="UTF-8">
<title>级联菜单_省份-城市</title>
<script type="text/javascript" src="js/show.js"></script>
</head>
<body>
    <div>
        省份:<select id="area" name="area">
            <option value="0">=== 请选择省份 ===</option>
        </select>
        城市:<select id="areaplus" name="areaplus">
            <option value="0">=== 请选择城市 ===</option>
        </select>
    </div>
</body>
</html>

show.js(js中实现Ajax与XML的交互):

// 页面加载时的事件处理
window.onload = function(){
    area() ;
    document.getElementById("area").addEventListener("change",function(){
        areaplus(this.value) ;
    },false) ;
}

// 定义Ajax操作对象
var xmlHttpRequest ;
// 定义可重用的Ajax操作方法,用来加载相应的数据
function load(urlMsg){
    // 将Ajax操作对象取出
    xmlHttpRequest = new XMLHttpRequest() ;
    console.log("测试Ajax操作对象" + xmlHttpRequest) ;
    // 设置请求并发送
    xmlHttpRequest.open("post",urlMsg) ;
    xmlHttpRequest.send(null) ;
}
// 利用Ajax进行数据的处理,完成页面内容的填充
function getContent(urlMsg,selId,id,title){
    load(urlMsg) ;
    xmlHttpRequest.onreadystatechange = function(){
        // 当服务器端完成请求的处理时
    if (xmlHttpRequest.readyState == 4 || xmlHttpRequest.status == 200){
        // 是城市菜单时要先清空之前的菜单内容
        if (selId == "areaplus"){
            clear() ;
        }
        // 取得对应的XML数据
        var xmlData = xmlHttpRequest.responseXML ;
        // 获取下拉列表框对象
        var select = document.getElementById(selId) ;
        // 取得XML数据中的所有id和title
        var idList = xmlData.getElementsByTagName(id) ;
        var titleList = xmlData.getElementsByTagName(title) ;
        // 创建所有的option并配置到下拉菜单中
        for (var i = 0 ; i < idList.length ; i ++){
            var option = document.createElement("option") ;
            option.setAttribute("value",idList[i].firstChild.nodeValue) ;
            option.appendChild(document.createTextNode(titleList[i].firstChild.nodeValue)) ;
            select.appendChild(option) ;
            }
        }
    }
}
// 显示所有的省份到下拉菜单中
function area(){
    getContent("AreaServlet","area","aid","title") ;
}
// 通过省份的下拉菜单动态显示所有的城市到下拉菜单中
function areaplus(aid){
    if (aid == "0"){ 
        // 如果没有选择省份数据时清空城市下拉列表
        clear() ;
    }else{
        // 进行内容显示的一系列操作,交给getContent()方法
        getContent("AreaplusServlet?aid=" + aid,"areaplus","apid","title") ;
    }
}
// 清空数据
function clear(){
    // 获取城市的下拉菜单对象,用来删除
    var select = document.getElementById("areaplus") ;
    // 由下拉菜单获取所有的option
    var optionList = select.getElementsByTagName("option") ;
    // 取得option的数量,遍历执行删除
    var len = optionList.length ;
    for (var i = 0 ; i < len - 1 ; i ++){
        select.removeChild(optionList[1]) ;
    }
}

AreaServlet(省份处理):

@WebServlet("/AreaServlet")
public class AreaServlet extends HttpServlet {
    protected void doGet(HttpServletRequest request,HttpServletResponse response)
            throws servletexception,IOException {
        this.doPost(request,response);
    }
    protected void doPost(HttpServletRequest request,IOException {
        request.setCharacterEncoding("UTF-8");
        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/xml");
        IAreaService areaService = ServiceFactory.getInstance(AreaServiceImpl.class);
        try {
            // 从数据层取出所有的Area
            List<Area> allArea = areaService.list();
            // 使用DOM4J取出Area内容,并最终生成XML传到前台
            Document document = DocumentHelper.createDocument();
            // 创建根节点
            Element areasEle = document.addElement("areas");
            // 从allArea中取出所有的值对象,设置到每个area节点中
            for (Area areaVO : allArea) {
                // 创建子节点,对子节点的创建一定要放在遍历代码块中,因为节点的数量随着值对象的数量而改变
                Element area = areasEle.addElement("area");
                Element aid = area.addElement("aid");
                Element title = area.addElement("title");
                aid.setText(String.valueOf(areaVO.getAid()));
                title.setText(areaVO.getTitle());
            }
            // XML设置完成后,开始进行一些列操作,将数据向前台输出
            OutputFormat output = OutputFormat.createCompactFormat();
            output.setEncoding("UTF-8");
            // 设置输出位置为客户端(前台)
            XMLWriter writer = new XMLWriter(response.getWriter(),output);
            // 进行XML的输出
            writer.write(document);
        } catch (Exception e) {
            e.printstacktrace();
        }
    }
}

AreaplusServlet(城市处理):

@WebServlet("/AreaplusServlet")
public class AreaplusServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request,HttpServletResponse response) throws servletexception,response);
    }
    @Override
    protected void doPost(HttpServletRequest request,IOException {
        request.setCharacterEncoding("UTF-8") ;
        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/xml");
        IAreaplusService areaplusService = ServiceFactory.getInstance(AreaplusServiceImpl.class) ;
        try {
            // 取出所有的城市数据,取之前要先从客户端接收身份编号
            Integer aid = Integer.parseInt(request.getParameter("aid")) ;
            List<Areaplus> allAreaplus = areaplusService.listByArea(aid) ;
            // 使用DOM4J生成DOM树,输出XML数据到客户端(前台)
            Document document = DocumentHelper.createDocument() ;
            // 创建根节点
            Element areaplusRoot = document.addElement("areapluss") ;
            // 为所有的areaplus创建子节点,首先要迭代所有的areaplus
            Iterator<Areaplus> iter = allAreaplus.iterator();
            while(iter.hasNext()){
                Areaplus vo = iter.next() ;
                // 开始子节点的创建和配置
                Element areaplus = areaplusRoot.addElement("areaplus") ;
                Element apid = areaplus.addElement("apid") ;
                Element title = areaplus.addElement("title") ;
                // 设置每个节点的内容
                apid.setText(String.valueOf(vo.getApid()));
                title.setText(vo.getTitle());
            }
            // DOM树生成之后,开始进行一系列的操作完成对客户端的数据传输
            OutputFormat output = OutputFormat.createCompactFormat() ;
            output.setEncoding("UTF-8");
            // 获取流对象,通过构造设置输出位置到客户端,并设置传输方式为紧凑方式和UTF-8的编码方式
            XMLWriter writer = new XMLWriter(response.getWriter(),output) ;
            // 进行内容的输出
            writer.write(document); 
        } catch (Exception e) {
            e.printstacktrace();
        }
    }
}

Ajax+XML实现级联下拉菜单的动态加载的更多相关文章

  1. HTML5单选框、复选框、下拉菜单、文本域的实现代码

    这篇文章主要介绍了HTML5单选框、复选框、下拉菜单、文本域的实现代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. html5写一个BUI折叠菜单插件的实现方法

    这篇文章主要介绍了html5写一个BUI折叠菜单插件的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  3. 关于h5中的fetch方法解读(小结)

    这篇文章主要介绍了关于h5中的fetch方法解读(小结),fetch身为H5中的一个新对象,他的诞生,是为了取代ajax的存在而出现,有兴趣的可以了解一下

  4. ios – 使用NSURLSession获取JSON数据

    我试图从谷歌距离api使用NSURLSession获取数据,但如下所示,当我打印响应和数据时,我得到的结果为NULL.可能是什么问题?

  5. ios – 错误域= com.alamofire.error.serialization.response代码= -1011“请求失败:禁止

    任何人都可以帮我解决以下错误–>在AFNetworking2.5中使用“删除”方法时出错解决方法我发现,如果我的手机时钟不同步……它不允许我更新…也许检查你的手机设置到正确的时间“自动区”,看看是否有效…

  6. iOS网页/原生应用Facebook登录弹出 – 失败?

    如果我重新启动app/web-app,用户将自动登录,并重定向到成功页面.我认为是导致问题的原因当您在Firefox/Chrome/Safari浏览器中运行网页时,Facebook登录对话框会弹出一个弹出窗口或另一个选项卡.我相信这是这个弹出页面的一个问题,以及当成功登录时Javascript如何与自身通信.window.close的东西没有返回的根页面…失败的解决方法由于应用程序挂在前面提到的URL上,我决定在shouldStartLoadWithRequest(…)中添加if语句以强制UIWebvie

  7. ios – Watchkit新会话不起作用

    我的手表扩展中有两个视图控制器.每当我打电话时我只得到第一个视图控制器的响应,并在第二个viewcontroller中得到错误WCSession在app和watch扩展中启动.任何建议?

  8. 使用Firebase iOS Swift将特定设备的通知推送到特定设备

    我非常感谢PushNotifications的帮助.我的应用聊天,用户可以直接向对方发送短信.但是如果没有PushNotifications,它就没有多大意义.它全部设置在Firebase上.如何将推送通知从特定设备发送到特定设备?

  9. ios – 保存从查询中获取的用户的属性(即不在currentUser上)

    我有兴趣根据currentUser执行的操作将属性保存到数据库中的用户.基于以下代码,我收到错误消息“除非已通过logIn或signUp验证用户,否则无法保存用户”我想知道是否有一个解决方法,我可以将属性保存到foundUser,而无需登录该用户.谢谢你的帮助!解决方法如果要更新当前不是登录用户的用户,则需要使用主密钥调用Parse.您可以从CloudCode执行此操作;并从您的iOS项目中调用它;

  10. 在iOS中使用NSJSONSerialization进行JSON解析

    解决方法首先在您的JSON响应字典中,在“RESPONSE”键下,您有一个数组而不是字典,该数组包含字典对象.所以要提取用户名和电子邮件ID,如下所示

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部