亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

AJAX級聯下拉框的簡單實現案例

2024-09-01 08:32:35
字體:
來源:轉載
供稿:網友
本篇文章主要是對AJAX級聯下拉框的簡單實現案例進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助

需要的JAVA類

復制代碼 代碼如下:


package com.ajaxlab.ajax;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;
import com.ajaxlab.ajax.ProductClass;

public class ClassService {
   private Document dom;
   public ClassService(){
    try{
     SAXBuilder builder=new SAXBuilder();
     this.dom=builder.build(ClassService.class.getResource("product.xml"));
    }catch(Exception e){
    e.printStackTrace();
    }
   }
   public ProductClass[] getAllClass1(){
    Collection products=new ArrayList();
    Iterator iterator=this.dom.getRootElement().getChildren().iterator();
    do{
     Element element=(Element)iterator.next();
     ProductClass product=new ProductClass(element.getAttributeValue("id"),
                                     element.getAttributeValue("className"));  
        products.add(product);
    }while(iterator.hasNext());
    return (ProductClass[])products.toArray(new ProductClass[0]);

   }

   public ProductClass[] getAllClass2ById(String class1Id){
    Collection products=new ArrayList();
    Element classElement=null;
    Iterator iterator=this.dom.getRootElement().getChildren().iterator();
    do{
     Element element=(Element)iterator.next();
     if(class1Id.equalsIgnoreCase(element.getAttributeValue("id"))){
      classElement=element;
      break;
     }
    }while(iterator.hasNext());

    if(classElement!=null){
     Iterator iter=classElement.getChildren().iterator();
     do{
      Element element=(Element)iter.next();
      ProductClass product=new ProductClass(element.getAttributeValue("id"),
                                      element.getAttributeValue("className"));
               products.add(product);
     }while(iter.hasNext());
    return (ProductClass[])products.toArray(new ProductClass[0]);
    }
    else{
     return null;
    }
   }

 
   public ProductClass[] getAllClass3ById(String class1Id,String class2Id) {
  Collection products = new ArrayList();
  Element class1Element = null;
  Element class2Element = null;

  Iterator iterator = this.dom.getRootElement().getChildren().iterator();
  do {
   Element element = (Element)iterator.next();
   if(class1Id.equalsIgnoreCase(element.getAttributeValue("id"))) {
    class1Element = element;
    break;
   }
  }while(iterator.hasNext());

  if(class1Element!=null) {
   Iterator iter = class1Element.getChildren().iterator();
   do {
    Element element = (Element)iter.next();
    if(class2Id.equalsIgnoreCase(element.getAttributeValue("id"))) {
     class2Element = element;
     break;
    }
   }while(iter.hasNext());

   if(class2Element!=null) {
    Iterator iter2 = class2Element.getChildren().iterator();
    do {
     Element element = (Element)iter2.next();
     ProductClass product = new ProductClass(element.getAttributeValue("id"),element.getAttributeValue("className"));
     products.add(product);
    }while(iter2.hasNext());
   }
   return (ProductClass[])products.toArray(new ProductClass[0]);
  }
  else return null;
}
}


<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE class SYSTEM "product.dtd" >
<class>
  <class1 className="電腦配件">
     <class2 className="內存">
       <class3 className="kingmax"></class3>
       <class3 className="kingston"></class3>
       <class3 className="samsung"></class3>
       <class3 className="hydadi"></class3>
       <class3 className="ibm"></class3> 
     </class2>
     <class2 className="硬盤">
       <class3 className="hithait"></class3>
       <class3 className="IBM"></class3>
       <class3 className="samsung"></class3>
       <class3 className="westdata"></class3>
     </class2>
  </class1>

  <class1 className="食品配件">
     <class2 className="漢堡包">
       <class3 className="麥當勞"></class3>
       <class3 className="肯得基"></class3>
       <class3 className="羅杰絲"></class3>
     </class2>
     <class2 className="飲料">
       <class3 className="cocacola"></class3>
       <class3 className="sprite"></class3>
       <class3 className="coffee"></class3>
       <class3 className="water"></class3>
     </class2>
  </class1>
</class>


<?xml version="1.0" encoding="GB2312" ?>
<!ELEMENT class (class1+)>
<!ELEMENT class1 (class2+)>
<!ATTLIST class1 className NMTOKEN #REQUIRED>
<!ATTLIST class1 id NMTOKEN #REQUIRED>
<!ELEMENT class2 (class3+)>
<!ATTLIST class2 className NMTOKEN #REQUIRED>
<!ATTLIST class2 id NMTOKEN #REQUIRED>
<!ELEMENT class3 EMPTY>
<!ATTLIST class3 className NMTOKEN #REQUIRED>
<!ATTLIST class3 id NMTOKEN #REQUIRED>

JSP:
(1)getClass.jsp 充當業務層供ajax調用
<%@ page contentType="text/html; charset=gb2312"%>
<%@ page import="com.ajaxlab.ajax.*"%>
<%
String class1Id = request.getParameter("class1Id");
String class2Id = request.getParameter("class2Id");
if("".equals(class1Id)) class1Id = null;
if("".equals(class2Id)) class2Id = null;
ClassService service = new ClassService();
if((class1Id!=null)&&(class2Id==null)) {
ProductClass[] classes = service.getAllClass2ById(class1Id);
if(classes!=null) {
  for(int i=0;i<classes.length;i++) {
   out.print(classes[i].getId()+","+classes[i].getClassName()+"|");
  }
}
}
else if((class1Id!=null)&&(class1Id!=null)) {
ProductClass[] classes = service.getAllClass3ById(class1Id,class2Id);
if(classes!=null) {
  for(int i=0;i<classes.length;i++) {
   out.print(classes[i].getId()+","+classes[i].getClassName()+"|");
  }
}
}
%>

(2)divmenu.jsp
<%@ page contentType="text/html; charset=gb2312"%>
<%@ page import="com.ajaxlab.ajax.*"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<script type="text/javascript" src="ajax_func.js" ></script>
<script type="text/javascript">

function doChange() {
var f = document.forms[0];
send_request("GET","getClass.jsp?class1Id="+f.select11.value+"&class2Id=",null,"TEXT",populateClass2);
}
function doChange2() {
var f = document.forms[0];
send_request("GET","getClass.jsp?class1Id="+f.select11.value+"&class2Id="+f.select12.value,null,"TEXT",populateClass3);
}
function populateClass2(){
     var f=document.forms[0];
     if(http_request.readystate==4){
       if(http_request.status==200){
          var list=http_request.responseText;
          var classList=list.split("|");
          f.select12.options.length=1;
          for(var i=0;i<classList.length-1;i++){
            var temp=Trim(classList[i]).split(",");
            f.select12.add(new Option(temp[1],temp[0]));
          }
       }
     }
}

  function populateClass3(){
     var f=document.forms[0];
     if(http_request.readystate==4){
       if(http_request.status==200){
          var list=http_request.responseText;
          var classList=list.split("|");
          f.select13.options.length=1;
          for(var i=0;i<classList.length-1;i++){
            var temp=Trim(classList[i]).split(",");
            f.select13.add(new Option(temp[1],temp[0]));
          }
       }
     }
   }
   function LTrim(str)
{
    var whitespace = new String(" /t/n/r");
    var s = new String(str);
    if (whitespace.indexOf(s.charAt(0)) != -1)
    {
        var j=0, i = s.length;
        while (j < i && whitespace.indexOf(s.charAt(j)) != -1)
        {
            j++;
        }
        s = s.substring(j, i);
    }
    return s;
}
function RTrim(str)
{
    var whitespace = new String(" /t/n/r");
    var s = new String(str);
    if (whitespace.indexOf(s.charAt(s.length-1)) != -1)
    {
        var i = s.length - 1;
        while (i >= 0 && whitespace.indexOf(s.charAt(i)) != -1)
        {
            i--;
        }
        s = s.substring(0, i+1);
    }
    return s;
}
function Trim(str)
{
    return RTrim(LTrim(str));
}
</script>
<%
  ClassService service = new ClassService();
  ProductClass[] classes = service.getAllClass1();
%>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
</head>
<body><center>
<form method="post" action="">
<select onchange="doChange(this.value)">
<option value="">請選擇分類一</option>
<%
for(int i=0;i<classes.length;i++) {
  out.println("<option value='"+classes[i].getId()+"'>"+classes[i].getClassName()+"</option>");
}
%>
</select>

<select onchange="doChange2(this.value)">
<option value="">請選擇分類二</option>
</select>

<select>
<option value="">請選擇分類三</option>
</select>
</form>
</center></body>
</html>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线日韩中文字幕| 久久亚洲精品小早川怜子66| 夜色77av精品影院| 亚洲精品影视在线观看| 中文字幕日韩免费视频| 色综合影院在线| 日韩av日韩在线观看| 久久久精品一区二区| 91高清在线免费观看| 中文字幕日韩欧美| 亚洲精品国精品久久99热一| 国产精品美女久久久久av超清| 亚洲精品国精品久久99热| 欧美高清videos高潮hd| 国内精品模特av私拍在线观看| 青青a在线精品免费观看| 欧日韩不卡在线视频| 亚洲精品视频久久| 亚洲国产精品va在看黑人| 欧美尺度大的性做爰视频| 午夜精品久久久久久久男人的天堂| 欧美成人免费视频| 菠萝蜜影院一区二区免费| 亚洲美女视频网站| 国产91精品视频在线观看| 国产精品成人v| 久久精品免费播放| 国产日本欧美一区二区三区| 国产精品久久久久久久美男| 欧美午夜丰满在线18影院| 最近中文字幕mv在线一区二区三区四区| 日韩av在线资源| 中文字幕欧美日韩精品| 久久成人免费视频| 久久久久久18| 欧美视频中文在线看| 亚洲天堂av在线播放| 2021久久精品国产99国产精品| 97视频在线观看免费高清完整版在线观看| 91社区国产高清| 国产精品欧美激情| 欧美视频在线观看 亚洲欧| 欧美在线影院在线视频| 欧美黑人巨大xxx极品| 亚洲人成在线播放| 奇米一区二区三区四区久久| 亚洲免费视频观看| 日韩经典第一页| 日韩成人中文字幕在线观看| 欧美精品做受xxx性少妇| 91国产精品电影| 日韩在线视频免费观看| 久久777国产线看观看精品| 全亚洲最色的网站在线观看| 国产欧美精品日韩精品| 亚洲综合中文字幕68页| 91精品国产高清久久久久久久久| 97在线观看视频国产| 91免费视频网站| 免费97视频在线精品国自产拍| 国产日韩在线一区| 亚洲第一区第二区| 欧美精品videosex性欧美| 欧美日韩亚洲激情| 热久久美女精品天天吊色| 久久视频免费在线播放| 国产精品99免视看9| 久久久久久久久中文字幕| 日韩欧美在线视频日韩欧美在线视频| 欧美激情一区二区久久久| 亚洲品质视频自拍网| 日本人成精品视频在线| 精品国产一区二区三区久久| 国产亚洲一区精品| 国产精品美女999| 久久久精品国产| 久久久亚洲福利精品午夜| 亚洲国产女人aaa毛片在线| 亚洲人成网站999久久久综合| 美女久久久久久久久久久| 欧美激情久久久久久| 国产日韩精品入口| 亚洲国产日韩欧美在线动漫| 91精品在线看| 国产日韩欧美91| 亚洲国产美女精品久久久久∴| 成人欧美一区二区三区黑人孕妇| 日韩高清人体午夜| 国产精品久久久久9999| 懂色av中文一区二区三区天美| 久久999免费视频| 日韩电影中文 亚洲精品乱码| 国产成人精品久久二区二区| 大胆人体色综合| 久久在线免费观看视频| 亚洲欧洲在线看| 国产精品亚发布| 欧美综合第一页| 国产成人午夜视频网址| 欧美日韩国产丝袜另类| 亚洲裸体xxxx| 国产xxx69麻豆国语对白| 日本三级韩国三级久久| 欧美日韩国产专区| 中文字幕一区二区精品| 欧美亚洲免费电影| 日韩精品免费在线观看| 欧美激情成人在线视频| 亚洲欧洲在线免费| 久久人人爽人人爽人人片亚洲| 98精品在线视频| 中文字幕久久精品| 国产69久久精品成人| 国产精品久久久久久av| 亚洲大胆人体视频| 欧美另类极品videosbestfree| 国产日韩欧美在线观看| 欧美韩国理论所午夜片917电影| 日本伊人精品一区二区三区介绍| 91九色国产社区在线观看| 日韩专区中文字幕| 国产精品xxx视频| 黄色成人在线免费| 久久视频在线免费观看| 国产亚洲精品久久| 亚洲专区中文字幕| 91日韩在线播放| 91久久夜色精品国产网站| 精品国产一区二区三区久久狼黑人| 亚洲r级在线观看| 国产亚洲视频在线观看| 欧美巨大黑人极品精男| 精品亚洲国产成av人片传媒| 26uuu亚洲国产精品| 青青a在线精品免费观看| 一本久久综合亚洲鲁鲁| 91精品国产综合久久香蕉922| xxxx欧美18另类的高清| 久久精品小视频| 深夜福利亚洲导航| 日本午夜精品理论片a级appf发布| 亚洲最大av网站| 成人性生交大片免费看小说| 国产成人免费av| 色偷偷av亚洲男人的天堂| 国产不卡av在线免费观看| 91精品国产91| 亚洲r级在线观看| 日韩在线欧美在线国产在线| 亚洲free性xxxx护士白浆| 欧美性色视频在线| 亚洲综合精品伊人久久| 欧美激情一二区| 91精品国产高清久久久久久91| 欧美激情国内偷拍| 国产精品va在线播放我和闺蜜| 久久天天躁狠狠躁夜夜躁2014| 81精品国产乱码久久久久久| 国产精品国产自产拍高清av水多| 亚洲国产欧美日韩精品| 精品国产欧美一区二区五十路| 国产91九色视频| 日韩在线观看电影| 日韩黄色高清视频|