`
猪↘專屬|华
  • 浏览: 164027 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

AJAX实现的二级级联菜单

    博客分类:
  • ajax
阅读更多

由于项目需求,需要做一个级联下拉列表,上网找了很多的东东,都不好,而且有时候跟项目中的js产生了冲突,所以,只好自己动手写了一个,ajax可以返回两种类型,一个是字符串,一个是xml文档型,以前实现ajax都是采用的串行,今天,做的这个ajax是返回的一个xml对象类型........

看实例:

index.jsp

<%@ 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++){
      //<select><value>1</value><text>昌平</text></select>
        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>
web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.5" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee   http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <servlet>
    <servlet-name>action</servlet-name>
    <servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
    <init-param>
      <param-name>config</param-name>
      <param-value>/WEB-INF/struts-config.xml</param-value>
    </init-param>
    <init-param>
      <param-name>debug</param-name>
      <param-value>3</param-value>
    </init-param>
    <init-param>
      <param-name>detail</param-name>
      <param-value>3</param-value>
    </init-param>
    <load-on-startup>0</load-on-startup>
  </servlet>
  <servlet>
    <servlet-name>SelectServlet</servlet-name>
    <servlet-class>com.util.SelectServlet</servlet-class>
  </servlet>
  <servlet>
    <servlet-name>ChangeServlet</servlet-name>
    <servlet-class>com.util.ChangeServlet</servlet-class>
  </servlet>

 

  <servlet-mapping>
    <servlet-name>action</servlet-name>
    <url-pattern>*.do</url-pattern>
  </servlet-mapping>

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

SelectServlet.java

package com.util;

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
    {
    }

}
这样就可以实现二级的级联菜单了,由这个例子,我想到了,项目中需要做局部刷新的功能,就是将表格中的内容,调用数据库中 的数据替换掉,当然了,这种方法可以用传统的方法实现,但是,给客户的感觉不好,所以,基本上不用,现在都用ajax,来实现。

1
0
分享到:
评论
1 楼 yinghuayu1324117 2011-03-21  

相关推荐

    jQuery+ajax实现三级级联

    在这个“jQuery+ajax实现三级级联”的实例中,我们主要探讨如何利用这两种技术来创建一个能够逐级联动的下拉菜单系统,这在数据筛选和表单填写中十分常见,如地区选择、部门分类等场景。 首先,jQuery是一个轻量级...

    Ajax (jQuery) 全国城市三级级联菜单插件

    在本案例中,我们讨论的是使用jQuery库实现的全国城市三级级联菜单插件,它使得用户能够在下拉菜单中选择省份、城市以及区县,以实现快速筛选或输入数据的目的。 首先,jQuery是一个广泛使用的JavaScript库,它简化...

    ajax实现二级级联(采用了递规调用)

    在网页开发中,二级级联菜单常常...通过学习这个知识点,开发者不仅可以掌握如何使用Ajax和递归实现二级级联菜单,还能了解到前后端协作、用户交互设计等方面的重要实践。这将有助于提升开发者的技能和项目实施能力。

    JSP+AJAX+MYSQL实现二级级联菜单

    在IT领域,构建动态、交互性强的Web应用是常见的需求,而"JSP+AJAX+MYSQL实现二级级联菜单"就是一个典型的实例。这个技术组合主要用于创建能够实时更新且具有前后端交互功能的Web界面,使得用户在选择一级菜单时,...

    java/jsp 实现二级级联菜单

    实现二级级联菜单主要涉及以下几个步骤: 1. **数据库设计**: 在数据库层面,你需要创建一个表来存储类别信息,这个表通常包含`id`(唯一标识符)、`name`(类别名称)、`parent_id`(父类别ID)等字段。通过`...

    使用Ajax实现三级级联菜单获取区号与邮政编码 PHP MySQL

    在本文中,我们将深入探讨如何使用Ajax技术来实现一个三级级联菜单,该菜单能够动态地获取并显示区号和邮政编码。这个功能是通过PHP和MySQL数据库进行后端处理来实现的,使得用户能够在前端界面中流畅地选择地理位置...

    二级级联菜单

    总结来说,这个项目结合了前端的jQuery交互与后端的MySQL数据获取,通过Servlet作为桥梁,实现了动态加载的二级级联菜单。这个过程中,前端和后端的紧密协作是关键,以确保用户体验流畅且数据实时更新。

    dwr实现2级级联菜单(sql2000 数据库)

    本篇文章将深入探讨如何利用DWR来实现一个两级级联菜单,并以SQL Server 2000数据库作为数据源。 首先,我们需要理解DWR的基本工作原理。DWR允许在后台执行Java方法并返回结果到前端,无需刷新整个页面。这种技术...

    Ajax实现三级级联

    在Web开发中,"Ajax实现三级级联"是一种常见的交互技术,主要用于提升用户体验,使得用户在选择一项数据时,相关的下级数据能够自动更新而无需刷新整个页面。在这个场景中,例如省份、城市、区县的三级联动选择,...

    ajax二级联动菜单

    本教程将深入探讨如何使用Ajax实现二级级联菜单。 首先,我们需要理解什么是Ajax。Ajax是一种创建动态网页的技术,通过JavaScript向服务器发送异步请求,并在后台获取数据后更新页面的部分内容,实现了用户与网页的...

    jquery+ajax+jsp+servlet实现二级级联菜单

    ### 使用jQuery、Ajax、JSP与Servlet实现二级级联菜单 #### 一、项目背景与技术栈概述 本文档将详细介绍如何使用jQuery、Ajax、JSP与Servlet来实现一个简单的二级级联菜单功能。该功能常见于许多Web应用程序中,如...

    Jquery实现ajax二级级联查询

    本主题聚焦于“Jquery实现ajax二级级联查询”,这是一个常见的前端交互设计,常见于下拉菜单联动,例如省份选择后自动更新城市选择。在这个场景中,我们通常会利用服务器端(如JSP或Servlet)动态生成XML文件,因为...

    javascript.和ajax实现二级联动菜单

    1、javascript实现二级联动:运用jsp标签拼写Javascript代码,实现一个二维数组,点击一级栏目时,查询二维数组里...2,ajax实现的二级联动:利用Ajax与后台程序实现异步交互,后台程序拼写JOSN字符串,发送到客户端。

    js+ajax实现三级级联

    在网页开发中,"js+ajax实现三级级联" 是一种常见的交互设计,它主要用于下拉选择框(select)的联动效果。这种效果通常应用于地址选择、部门分类等场景,用户在选择第一级后,第二级和第三级的选项会根据前一级的...

    java web下开发二级级联下拉菜单(数据库实现的)

    总之,通过结合Java Web技术和数据库,我们可以实现动态的二级级联下拉菜单,为用户提供直观且易于操作的界面。这个过程涉及到数据库设计、后端服务开发以及前端交互等多个环节,对提升开发者综合能力非常有帮助。

    java实现Ajax级联菜单

    总结来说,这个"java实现ajax二级联菜单"的项目涉及到以下关键点: 1. Java Servlet:处理来自前端的Ajax请求,查询数据库并返回数据。 2. Ajax:使用JavaScript异步更新二级菜单,提高交互性。 3. HTML和...

    ajax实现级联菜单的类子

    本文将深入探讨如何使用Ajax来实现级联菜单,并结合数据库获取数据。 首先,我们需要理解Ajax的工作原理。Ajax的核心是XMLHttpRequest对象,它允许JavaScript在不重新加载整个页面的情况下与服务器进行异步通信。...

    jsp+json+mySql 实现二级级联下拉菜单

    在本文中,我们将深入探讨如何使用JSP、JSON和MySQL来实现一个二级级联下拉菜单。这个功能常用于网站的表单设计中,让用户能够从相关联的分类中选择选项,例如省份与城市的选择。 首先,让我们了解这三个技术的核心...

    ajax实现下拉列表级联

    在本文中,我们将深入探讨如何使用Ajax技术来实现下拉列表的级联效果,这是一个常见的交互功能,特别是在数据录入和筛选场景中。我们将基于EJB(Enterprise JavaBeans)技术连接数据库,以动态加载和更新下拉列表...

Global site tag (gtag.js) - Google Analytics