客户端触发:

<select id="category1" onchange="changecategory()">
    <option value="-1">所有一级类别</option>
   <%
    for(int i=0; i<topCategorys.size(); i++) {
     Category c = topCategorys.get(i);
   %>
      <option value="<%=c.getId() %>"><%=c.getName() %></option>
   <%
    }
    %>
   </select>
   <select id="category2">
    <option value="-1">所有二级类别</option>
   </select>

创建XHR:
<script type="text/javascript">
  var req;
  function changecategory() {
   if(window.XMLHttpRequest) {
    req = new XMLHttpRequest();
   } else if (window.ActiveXObject) {
    req = new ActiveXObject("Microsoft.XMLHTTP");
   }
   var id = document.getElementById("category1").options[document.getElementById("category1").selectedIndex];
   var url = "getchildcategory.jsp?id=" + escape(id.value);

req.open("GET", url, true);
   req.onreadystatechange=callback;
   req.send(null);
  }
  function callback() {
   if (req.readyState == 4) {
    if (req.status == 200) {

  //parseXml(req.responseXML);//方式1:XML方式(太麻烦)

  //parse(req.responseText);//方式2:字符方式(最常用)
     eval(req.responseText);//方式3:动态生成javascript方式(最常用)
      } 
     }
  }

function parseXml(msg) {
   var categorys = msg.getElementsByTagName("categorys")[0];
   //alert(categorys.childNodes.length);
   document.getElementById("category2").length=categorys.childNodes.length+1;
   document.getElementById("category2").selectedIndex=0;
   for(var i=0; i<categorys.childNodes.length; i++) {
    var category = categorys.childNodes[i];
    var id = category.childNodes[0].childNodes[0].nodeValue;
    //alert(id);
    var name = category.childNodes[1].childNodes[0].nodeValue;
    //alert(name);
    document.getElementById("category2").options[i+1].value=id;
    document.getElementById("category2").options[i+1].text=name;
   }
  }

function parse(msg) {
   //alert("|" + msg + "|");
   msg = msg.replace(/(^\s*)|(\s*$)/g, "");
   if(msg == null || new String(msg) == "") {
    return;
   }
   var categorys = msg.split("-");
   for(var i=0; i<categorys.length; i++) {
    var category = categorys[i].split("&");
    var id = category[0];
    var name = category[1];
    document.getElementById("category2").length=categorys.length+1;
    document.getElementById("category2").selectedIndex=0;
    document.getElementById("category2").options[i+1].value=id;
    document.getElementById("category2").options[i+1].text=name;
   }
  }
 </script>

server处理方式(getchildcategory.jsp中的内容),返回包含处理结果的javascript代码:

<%
 String strId = request.getParameter("id");
 int id = -1;
 if(strId != null && !strId.trim().equals("")) {
  id = Integer.parseInt(request.getParameter("id"));
 }
 Category parent = CategoryMgr.getInstance().loadById(id);
 List<Category> childs = parent.getChilds();
 StringBuffer buff = new StringBuffer();

//方式1:XML方式

/*

for(int i=0; i<childs.size(); i++) {
  Category c = childs.get(i);
  buff.append("<category><id>" + c.getId() + "</id><name>" + c.getName() + "</name></category>");
 }
 buff.insert(0,"<categorys>");
 buff.append("</categorys>");

*/

//方式2:字符方式

/*

for(int i=0; i<childs.size(); i++) {
  Category c = childs.get(i);
  buff.append(c.getId() + "&" + c.getName() + "-");
 }
 if(childs.size() > 0){
  buff.deleteCharAt(buff.length()-1);
 }
 */

//方式3:动态生成javascript方式
 for(int i=0; i<childs.size(); i++) {
  Category c = childs.get(i);
  buff.append("document.getElementById('category2').options[" + (i+1) + "].value=" + c.getId() + ";\n");
  buff.append("document.getElementById('category2').options[" + (i+1) + "].text='" + c.getName() + "';\n");
 }
 buff.insert(0, "document.getElementById('category2').selectedIndex=0;\n");
 buff.insert(0, "document.getElementById('category2').length=" + (childs.size()+1) +";\n");
 
System.out.println(buff.toString());

//可以采用清除缓存的方法,如下
 response.setContentType("text/xml");
 response.setHeader("Cache-Control", "no-store"); //HTTP1.1 
 response.setHeader("Pragma", "no-cache"); //HTTP1.0
 response.setDateHeader("Expires", 0);
 response.getWriter().write(buff.toString());
%>

下拉条的连动-ajax方式的更多相关文章

  1. 通过Ajax方式上传文件,使用FormData进行Ajax请求

    通过传统的form表单提交的方式上传文件: <form id= "uploadForm" action= "http://localhost:8080/cfJAX_ ...

  2. ajax方式提交带文件上传的表单,上传后不跳转

    ajax方式提交带文件上传的表单 一般的表单都是通过ajax方式提交,所以碰到带文件上传的表单就比较麻烦.基本原理就是在页面增加一个隐藏iframe,然后通过ajax提交除文件之外的表单数据,在表单数 ...

  3. OSS web直传 ajax方式 上传图片、文件

    部分js代码 send_request = function(){//这是从后台获取认证策略等信息. var htmlobj=$.ajax({url:root+"/service/polic ...

  4. [转] 通过Ajax方式上传文件,使用FormData进行Ajax请求

    通过传统的form表单提交的方式上传文件: <form id= "uploadForm" action= "http://localhost:8080/cfJAX_ ...

  5. 百度编辑器ueditor通过ajax方式提交,不需要事先转义字符的方法(异常:从客户端(xxx)中检测到有潜在危险的 Request.Form 值)

    最近项目中使用百度编辑神器ueditor,确实是很好用的一款编辑器.官网教程提供的与后端数据交互都是跟表单方式有关的,项目中使用的是ajax方式提交,因此出现了不少问题,现在记录备忘下. 环境:.ne ...

  6. jquery.validate ajax方式验证

    在做网站的时候有一块需要用到jquery.validate插件 ajax方式的方式来验证原始密码是否正确,研究了研究加上博客园朋友的帮助,终于实现了.贴出代码 <script type=&quo ...

  7. [实战]MVC5+EF6+MySql企业网盘实战(5)——ajax方式注册

    写在前面 今天贴合到实际的客户需求仔细的想了下,其实在userInfo这个类里面很多字段都不是必须的.有很多的事业单位根本就不能上网,填写的邮箱也是exchange的,个人的详细信息都在ad里面可以取 ...

  8. python笔记-20 django进阶 (model与form、modelform对比,三种ajax方式的对比,随机验证码,kindeditor)

    一.model深入 1.model的功能 1.1 创建数据库表 1.2 操作数据库表 1.3 数据库的增删改查操作 2.创建数据库表的单表操作 2.1 定义表对象 class xxx(models.M ...

  9. 阿里OSS ajax方式 web直传

    部分js代码 send_request = function(){//这是从后台获取认证策略等信息. var htmlobj=$.ajax({url:root+"/service/polic ...

随机推荐

  1. U - stl 的 优先队列 Ⅰ

    Description Given m sequences, each contains n non-negative integer. Now we may select one number fr ...

  2. B - 敌兵布阵 线段树的点

    B - 敌兵布阵 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descriptio ...

  3. 《C++ Primer Plus 6th》读书笔记 - 第十一章 使用类

    1. 运算符重载 2. 计算时间:一个运算符重载示例 3. 友元 1. 友元有三种: 友元函数 友元类 友元成员函数 4. 重载运算符:作为成员函数还是非成员函数 5. 再谈重载:一个矢量类 6. 类 ...

  4. Repeater实现数据绑定

    Repeater基础 在aspx文件中加入Repeater 控件,在<ItemTemplate></ItemTemplate>包含的范围里加入自己控制的代码,需要替换的变量使用 ...

  5. HTML5学习笔记-video

    HTML5 <video> - 方法.属性以及事件 方法 play()——播放 pause()——暂停 load()——加载 canPlayType——检测您的浏览器是否能播放不同类型的视 ...

  6. Python: xml转json

    1,引言 GooSeeker早在9年前就开始了Semantic Web领域的产品化,MS谋数台和DS打数机是其中两个产品.对web内容做结构化转换和语义处理的主要路线是 XML -> RDF - ...

  7. Android网络编程概述

    Android网络编程概述 首先,应该了解的几个问题: 1)Android平台网络相关API接口 a) java.net.*(标准Java接口) java.net.*提供与联网有关的类,包括流.数据包 ...

  8. 環氧樹脂對COB的影響

    COB的封膠一般使用單液 Epoxy(環氧樹脂),也可以使用雙液(Epoxy+硬化劑),雙液的成品品質可靠度雖然比較高,但是保存及維護非常麻煩,所以一般的 COB 都還是採用單液的製程. 其次是如何控 ...

  9. 【javascript 对日期的扩展 Format\addDays】

    // 对Date的扩展,将 Date 转化为指定格式的String // 月(M).日(d).小时(H).分(m).秒(s).季度(q) 可以用 1-2 个占位符, // 年(y)可以用 1-4 个占 ...

  10. 怎么去掉word标题前的黑点

    原文地址:http://jingyan.baidu.com/article/9c69d48f593c5b13c9024e2c.html 我们在使用word时,标题前总是出现黑点,其实这个黑点在打印时是 ...