Ajax动态加载列表框

前端之家收集整理的这篇文章主要介绍了Ajax动态加载列表框前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

1.dynamicLists.html:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Dynamically Filling Lists</title>

<script type="text/javascript">
var xmlHttp;

function createXMLHttpRequest() {
    if (window.ActiveXObject) {
        xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
    } 
    else if (window.XMLHttpRequest) {
        xmlHttp = new XMLHttpRequest();
    }
}
    
function refreshModelList() {
    var make = document.getElementById("make").value;
    var modelYear = document.getElementById("modelYear").value;

    if(make == "" || modelYear == "") {
        clearModelsList();
        return;
    }
    
    var url = "RefreshModelList?" 
        + createQueryString(make,modelYear) + "&ts=" + new Date().getTime();
        
    createXMLHttpRequest();
    xmlHttp.onreadystatechange = handleStateChange;
    xmlHttp.open("GET",url,true);
    xmlHttp.send(null);
}

function createQueryString(make,modelYear) {
    var queryString = "make=" + make + "&modelYear=" + modelYear;
    return queryString;
}
    
function handleStateChange() {
    if(xmlHttp.readyState == 4) {
        if(xmlHttp.status == 200) {
            updateModelsList();
        }
    }
}

function updateModelsList() {
    clearModelsList();
    
    var models = document.getElementById("models");
    var results = xmlHttp.responseXML.getElementsByTagName("model");
    var option = null;
    for(var i = 0; i < results.length; i++) {
        option = document.createElement("option");
        option.appendChild(document.createTextNode(results[i].firstChild.nodeValue));
        models.appendChild(option);
    }
}

function clearModelsList() {
    var models = document.getElementById("models");
    while(models.childNodes.length > 0) {
        models.removeChild(models.childNodes[0]);
    }
}
</script>
</head>

<body>
  <h1>Select Model Year and Make</h1>
  
  <form action="#">
    <span style="font-weight:bold;">Model Year:</span>
    <select id="modelYear" onchange="refreshModelList();">
        <option value="">Select One</option>
        <option value="2006">2006</option>
        <option value="1995">1995</option>
        <option value="1985">1985</option>
        <option value="1970">1970</option>
    </select>
    
    <br/><br/>
    <span style="font-weight:bold;">Make:</span>
    <select id="make" onchange="refreshModelList();">
        <option value="">Select One</option>
        <option value="Chevrolet">Chevrolet</option>
        <option value="Dodge">Dodge</option>
        <option value="Pontiac">Pontiac</option>
    </select>
    
    <br/><br/>
    <span style="font-weight:bold;">Models:</span>
    <br/>
    <select id="models" size="6" style="width:300px;">    
    </select>  
  </form>

</body>
</html>


2.RefreshModelListServlet.java:

package com.wch.ajax.servlet;

import java.io.*;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import javax.servlet.*;
import javax.servlet.http.*;

public class RefreshModelListServlet extends HttpServlet {

    private static List availableModels = new ArrayList();
    
    protected void processRequest(HttpServletRequest request,HttpServletResponse response)
    throws ServletException,IOException {
        response.setContentType("text/html;charset=UTF-8");
        
        int modelYear = Integer.parseInt(request.getParameter("modelYear"));
        String make = request.getParameter("make");
        
        StringBuffer results = new StringBuffer("<models>");
        MakeModelYear availableModel = null;
        for(Iterator it = availableModels.iterator(); it.hasNext();) {
            availableModel = (MakeModelYear)it.next();
            if(availableModel.modelYear == modelYear) {
                if(availableModel.make.equals(make)) {
                    results.append("<model>");
                    results.append(availableModel.model);
                    results.append("</model>");
                }
            }
        }
        results.append("</models>");
        
        response.setContentType("text/xml");
        response.getWriter().write(results.toString());
    }
    
    protected void doGet(HttpServletRequest request,IOException {
        processRequest(request,response);
    }
    
    public void init() throws ServletException {
        availableModels.add(new MakeModelYear(2006,"Dodge","Charger"));
        availableModels.add(new MakeModelYear(2006,"Magnum"));
        availableModels.add(new MakeModelYear(2006,"Ram"));
        availableModels.add(new MakeModelYear(2006,"Viper"));
        availableModels.add(new MakeModelYear(1995,"Avenger"));
        availableModels.add(new MakeModelYear(1995,"Intrepid"));
        availableModels.add(new MakeModelYear(1995,"Neon"));
        availableModels.add(new MakeModelYear(1995,"Spirit"));
        availableModels.add(new MakeModelYear(1985,"Aries"));
        availableModels.add(new MakeModelYear(1985,"Daytona"));
        availableModels.add(new MakeModelYear(1985,"Diplomat"));
        availableModels.add(new MakeModelYear(1985,"Omni"));
        availableModels.add(new MakeModelYear(1970,"Challenger"));
        availableModels.add(new MakeModelYear(1970,"Charger"));
        availableModels.add(new MakeModelYear(1970,"Coronet"));
        availableModels.add(new MakeModelYear(1970,"Dart"));

        availableModels.add(new MakeModelYear(2006,"Chevrolet","Colorado"));
        availableModels.add(new MakeModelYear(2006,"Corvette"));
        availableModels.add(new MakeModelYear(2006,"Equinox"));
        availableModels.add(new MakeModelYear(2006,"Monte Carlo"));
        availableModels.add(new MakeModelYear(1995,"Beretta"));
        availableModels.add(new MakeModelYear(1995,"Camaro"));
        availableModels.add(new MakeModelYear(1995,"Cavalier"));
        availableModels.add(new MakeModelYear(1995,"Lumina"));
        availableModels.add(new MakeModelYear(1985,"Cavalier"));
        availableModels.add(new MakeModelYear(1985,"Chevette"));
        availableModels.add(new MakeModelYear(1985,"Celebrity"));
        availableModels.add(new MakeModelYear(1985,"Citation II"));
        availableModels.add(new MakeModelYear(1970,"Bel Air"));
        availableModels.add(new MakeModelYear(1970,"Caprice"));
        availableModels.add(new MakeModelYear(1970,"Chevelle"));
        availableModels.add(new MakeModelYear(1970,"Monte Carlo"));

        availableModels.add(new MakeModelYear(2006,"Pontiac","G6"));
        availableModels.add(new MakeModelYear(2006,"Grand Prix"));
        availableModels.add(new MakeModelYear(2006,"Solstice"));
        availableModels.add(new MakeModelYear(2006,"Vibe"));
        availableModels.add(new MakeModelYear(1995,"Bonneville"));
        availableModels.add(new MakeModelYear(1995,"Grand Am"));
        availableModels.add(new MakeModelYear(1995,"Grand Prix"));
        availableModels.add(new MakeModelYear(1995,"Firebird"));
        availableModels.add(new MakeModelYear(1985,"6000"));
        availableModels.add(new MakeModelYear(1985,"Fiero"));
        availableModels.add(new MakeModelYear(1985,"Grand Prix"));
        availableModels.add(new MakeModelYear(1985,"Parisienne"));
        availableModels.add(new MakeModelYear(1970,"Catalina"));
        availableModels.add(new MakeModelYear(1970,"GTO"));
        availableModels.add(new MakeModelYear(1970,"LeMans"));
        availableModels.add(new MakeModelYear(1970,"Tempest"));
    }

    private static class MakeModelYear {
        private int modelYear;
        private String make;
        private String model;
        
        public MakeModelYear(int modelYear,String make,String model) {
            this.modelYear = modelYear;
            this.make = make;
            this.model = model;
        }
    }
}


3.web.xml:

<servlet>
    <servlet-name>RefreshModelListServlet</servlet-name>
    <servlet-class>com.wch.ajax.servlet.RefreshModelListServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>RefreshModelListServlet</servlet-name>
    <url-pattern>/RefreshModelList</url-pattern>
  </servlet-mapping>

4.运行结果是:

猜你在找的Ajax相关文章