`
xiangqian0505
  • 浏览: 321249 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JAVA 二级联动菜单

    博客分类:
  • java
阅读更多
<%@ page language="java" pageEncoding="UTF-8"%>
<html>
    <head>
        <title>二级菜单联动演示</title>
        <script type="text/javascript">
    var req;
    window.onload=function()
    {//页面加载时的函数
    }
    
    function Change_Select(){//当第一个下拉框的选项发生改变时调用该函数
      var province = document.getElementById('province').value;
      var url = "select?id="+ escape(province);
      if(window.XMLHttpRequest){
        req = new XMLHttpRequest();
      }else if(window.ActiveXObject){
        req = new ActiveXObject("Microsoft.XMLHTTP");
      }
      if(req){
        req.open("GET",url,true);
         //指定回调函数为callback
        req.onreadystatechange = callback;
        req.send(null);
      }
    }
    //回调函数
    function callback(){
      if(req.readyState ==4){
        if(req.status ==200){
          parseMessage();//解析XML文档
        }else{
          alert("不能得到描述信息:" + req.statusText);
        }
      }
    }
    //解析返回xml的方法
    function parseMessage(){
      var xmlDoc = req.responseXML.documentElement;//获得返回的XML文档
      var xSel = xmlDoc.getElementsByTagName('select');
      //获得XML文档中的所有<select>标记
      var select_root = document.getElementById('city');
      //获得网页中的第二个下拉框
      select_root.options.length=0;
      //每次获得新的数据的时候先把每二个下拉框架的长度清0
      
      for(var i=0;i<xSel.length;i++){
        var xValue = xSel[i].childNodes[0].firstChild.nodeValue;
        //获得每个<select>标记中的第一个标记的值,也就是<value>标记的值
        var xText = xSel[i].childNodes[1].firstChild.nodeValue;
        //获得每个<select>标记中的第二个标记的值,也就是<text>标记的值
        
        var option = new Option(xText, xValue);
        //根据每组value和text标记的值创建一个option对象
        
        try{
          select_root.add(option);//将option对象添加到第二个下拉框中
        }catch(e){
        }
      }
    }        
  </script>
    </head>

    <body>
        <div align="center">
            <form name="form1" method="post" action="">
                <table width="70%" border="0" cellspacing="0" cellpadding="0">
                    <tr>
                        <td align="center">
                            二级联动示例
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <select name="province" id="province" onChange="Change_Select()">
                                <!–第一个下拉菜单–>
                                <option value="0">
                                    请选择
                                </option>
                                <option value="1">
                                    北京
                                </option>
                                <option value="2">
                                    天津
                                </option>
                                <option value="3">
                                    山东
                                </option>
                            </select>
                            <select name="city" id="city">
                                <!–第二个下拉菜单–>
                                <option value="0">
                                    请选择
                                </option>
                            </select>
                        </td>
                    </tr>
                    <tr>
                        <td>
                        </td>
                    <tr>
                </table>
            </form>
        </div>
    </body>
</html>

 

package com;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/***
 * 
 * @author zdw
 *
 */
public class SelectServlet extends HttpServlet
{

    private static final long serialVersionUID = 1L;

    public SelectServlet()
    {
        super();
    }

    public void destroy()
    {
        super.destroy();
    }

    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException
    {
//        response.setCharacterEncoding("GBK");
        response.setContentType("text/xml");
        response.setHeader("Cache-Control", "no-cache");
        request.setCharacterEncoding("GBK");
        response.setCharacterEncoding("UTF-8");
        String targetId = request.getParameter("id").toString();
        System.out.println(targetId);
        // 获得请求中参数为id的值
        String xml_start = "<selects>";
        String xml_end = "</selects>";
        String xml = "";

        if (targetId.equalsIgnoreCase("0"))
        {
            xml = "<select><value>0</value><text>请选择</text></select>";
        } else if (targetId.equalsIgnoreCase("1"))
        {
            xml = "<select><value>1</value><text>昌平</text></select>";
            xml += "<select><value>2</value><text>丰台</text></select>";
            xml += "<select><value>3</value><text>海淀</text></select>";
            xml += "<select><value>4</value><text>朝阳</text></select>";
        } else if (targetId.equalsIgnoreCase("2"))
        {
            xml = "<select><value>1</value><text>塘沽区</text></select>";
            xml += "<select><value>2</value><text>汉沽区</text></select>";
            xml += "<select><value>3</value><text>大港区</text></select>";
            xml += "<select><value>4</value><text>东丽区</text></select>";
        } else
        {// 如果是3,则返回下面的字符
            xml = "<select><value>1</value><text>济南</text></select>";
            xml += "<select><value>2</value><text>青岛</text></select>";
            xml += "<select><value>3</value><text>淄博</text></select>";
            xml += "<select><value>4</value><text>枣庄</text></select>";
        }

        String last_xml = xml_start + xml + xml_end;
        response.getWriter().write(last_xml);

    }

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException
    {
        doGet(request, response);
    }

    public void init() throws ServletException
    {
    }

}

 

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee 
    http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
    <servlet>
        <servlet-name>SelectServlet</servlet-name>
        <servlet-class>com.SelectServlet</servlet-class>
    </servlet>

    <servlet-mapping>
        <servlet-name>SelectServlet</servlet-name>
        <url-pattern>/select</url-pattern>
    </servlet-mapping>
    <welcome-file-list>
        <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>
</web-app>

 

分享到:
评论

相关推荐

    二级联动菜单

    在IT领域,二级联动菜单是一种常见的用户界面设计模式,它常用于导航系统或者数据筛选,让用户能够通过两层或更多层级的选择来精确找到所需的信息。这种菜单结构在网站、应用程序和软件中广泛应用,特别是在需要展示...

    Java二级联动

    在Java二级联动中,AJAX可以用来在不刷新整个页面的情况下,向服务器发送请求获取数据,使得用户体验更加流畅。通过`XMLHttpRequest`对象或现代浏览器的`fetch` API,前端可以发送异步请求,控制器响应这些请求并...

    java swing 实现3级联动菜单

    看了有人写的3级联动菜单,觉得代码太烦了,所以自己写了一个

    Java实现Map集合二级联动示例

    在这个"Java实现Map集合二级联动示例中国省市例子"中,我们将探讨如何使用Map来构建一个二级联动的功能,常见于如中国省市选择的场景。这个场景通常出现在需要用户首先选择省份,然后根据所选省份展示对应的市的选择...

    二级联动菜单(jsp mysql)

    在这个“二级联动菜单(jsp mysql)”的实例中,我们将探讨如何使用JavaServer Pages (JSP) 和 MySQL数据库来实现这种功能。 首先,JSP是Java的一种动态网页技术,它允许开发人员在HTML页面中嵌入Java代码,从而...

    java实现的二级联动菜单效果

    在Java Web开发中,二级联动菜单是一种常见的交互设计,它允许用户通过选择一级菜单来触发二级菜单的内容更新,常用于地区选择、分类筛选等场景。本篇将详细讲解如何使用Java实现这种效果。 首先,二级联动菜单的...

    jquery二级联动菜单

    java结合jquery进行异步提交在jsp页面中实现二级联动菜单,该源码在struts+mvc基础上实现的,简单明了。其中的数据库可自行更改,只要相应的更改连库字符串等即可。也可多加几个下拉框将项目扩展为多级联动菜单

    java联动菜单实例详解

    在Java编程中,联动菜单(通常称为级联菜单或下拉树菜单)是一种常见的用户界面元素,它允许用户从多个相关选项中进行选择,这些选项按照层次结构组织。本篇文章将深入探讨Java实现联动菜单的概念、设计以及相关技术...

    jsp+ajax 三级联动菜单

    【jsp+ajax 三级联动菜单】是一个典型的Web开发技术应用场景,它主要利用JavaServer Pages(JSP)和Asynchronous JavaScript and XML(AJAX)来实现动态网页中的数据交互和页面更新。在这个例子中,我们看到的是一个...

    最简单js代码实现select二级联动下拉菜单

    本文实例为大家分享了js实现select二级联动下拉菜单,供大家参考,具体内容如下 &lt;&#37;@ page language="java" import="java.util.*" pageEncoding="UTF-8"%&gt; &lt;&#37; String path = request.getContextPath()...

    省市联动二级菜单

    省市联动二级菜单,java script

    jsp从数据库获取数据填充下拉框实现二级联动菜单的方法.docx

    ### JSP从数据库获取数据填充下拉框实现二级联动菜单的方法 #### 一、引言 在Web开发中,为了提高用户体验和数据处理效率,经常需要实现动态数据填充功能,尤其是对于多级联动的选择菜单。本文将详细介绍如何利用...

    jsp+js实现的二级联动菜单.pdf

    在IT领域,尤其是在Web开发中,二级联动菜单是一种常见的交互设计,用于呈现具有层次关系的数据。这个案例中,我们讨论的是如何使用JSP(JavaServer Pages)和JavaScript来实现这样的功能,以提高用户体验并减少不必...

    js+servlet+struts 动态二级联动菜单

    在IT行业中,动态二级联动菜单是一种常见的用户界面设计技术,主要应用于网页或应用程序中,以提供用户更加便捷的导航和筛选功能。这种菜单系统能够根据用户的前一次选择自动更新下一个级别的选项,通常用于地区选择...

    从数据库中读取的二级联动菜单(ajax)

    在IT领域,尤其是在Web开发中,二级联动菜单是一种常见的交互设计元素,用于提供层次结构的选项选择。在本示例中,我们关注的是如何通过AJAX(异步JavaScript和XML)技术从数据库动态加载二级联动菜单的数据。这个...

    Java代码实现两级联动

    在提供的压缩包文件"用Java代码实现二级联动"中,可能包含了以下内容: - 一个Java类,实现了处理请求、获取数据和生成JSON响应的功能。 - HTML或JSP文件,包含了前端的界面结构和JavaScript代码,用于发送Ajax请求...

    用dwr做的二级联动菜单(可扩展为多级联动)

    使用dwr做的二级联动菜单,不会出现DWRUtil未定义的问题。不使用DWRUtil实现,依赖dwr.xml中的配置的实体实现二级联动。数据库采用mysql,字段简单可根据自己的情况建立数据库,根据pojo中的类建立表,然后把util...

    Spinner二级联动下拉菜单

    "Spinner二级联动下拉菜单"是一个更复杂的功能,它涉及到两个Spinner,一个选择省份,另一个根据省份的选择动态加载并显示对应的城市。这个功能的实现涉及到多个知识点,下面将逐一详细讲解。 1. **Spinner基本使用...

Global site tag (gtag.js) - Google Analytics