java AJAX实现级联下拉框
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="电脑配件" id="1"> <class2 className="内存" id="1"> <class3 id="1" className="kingmax"></class3> <class3 id="2" className="kingston"></class3> <class3 id="3" className="samsung"></class3> <class3 id="4" className="hydadi"></class3> <class3 id="5" className="ibm"></class3> </class2> <class2 className="硬盘" id="2"> <class3 id="6" className="hithait"></class3> <class3 id="7" className="IBM"></class3> <class3 id="8" className="samsung"></class3> <class3 id="9" className="westdata"></class3> </class2> </class1> <class1 className="食品配件" id="2"> <class2 className="汉堡包" id="1"> <class3 id="1" className="麦当劳"></class3> <class3 id="2" className="肯得基"></class3> <class3 id="3" className="罗杰丝"></class3> </class2> <class2 className="饮料" id="2"> <class3 id="4" className="cocacola"></class3> <class3 id="5" className="sprite"></class3> <class3 id="6" className="coffee"></class3> <class3 id="7" 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(" "); 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(" "); 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 name="classForm" method="post" action=""> <select name="select11" id="select11" 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 name="select12" id="select12" onchange="doChange2(this.value)"> <option value="">请选择分类二</option> </select> <select name="select13" id="select13"> <option value="">请选择分类三</option> </select> </form> </center></body> </html>
登录后复制
更多java AJAX实现级联下拉框相关文章请关注PHP中文网!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
刺客信条阴影:贝壳谜语解决方案
1 周前
By DDD
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前
By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Java的类上载涉及使用带有引导,扩展程序和应用程序类负载器的分层系统加载,链接和初始化类。父代授权模型确保首先加载核心类别,从而影响自定义类LOA

本文讨论了使用咖啡因和Guava缓存在Java中实施多层缓存以提高应用程序性能。它涵盖设置,集成和绩效优势,以及配置和驱逐政策管理最佳PRA

本文使用lambda表达式,流API,方法参考和可选探索将功能编程集成到Java中。 它突出显示了通过简洁性和不变性改善代码可读性和可维护性等好处

本文讨论了使用JPA进行对象相关映射,并具有高级功能,例如缓存和懒惰加载。它涵盖了设置,实体映射和优化性能的最佳实践,同时突出潜在的陷阱。[159个字符]

本文讨论了使用Maven和Gradle进行Java项目管理,构建自动化和依赖性解决方案,以比较其方法和优化策略。

本文使用选择器和频道使用单个线程有效地处理多个连接的Java的NIO API,用于非阻滞I/O。 它详细介绍了过程,好处(可伸缩性,性能)和潜在的陷阱(复杂性,

本文使用Maven和Gradle之类的工具讨论了具有适当的版本控制和依赖关系管理的自定义Java库(JAR文件)的创建和使用。

本文详细介绍了用于网络通信的Java的套接字API,涵盖了客户服务器设置,数据处理和关键考虑因素,例如资源管理,错误处理和安全性。 它还探索了性能优化技术,我
