下拉条的连动-ajax方式
客户端触发:
<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方式的更多相关文章
- 通过Ajax方式上传文件,使用FormData进行Ajax请求
通过传统的form表单提交的方式上传文件: <form id= "uploadForm" action= "http://localhost:8080/cfJAX_ ...
- ajax方式提交带文件上传的表单,上传后不跳转
ajax方式提交带文件上传的表单 一般的表单都是通过ajax方式提交,所以碰到带文件上传的表单就比较麻烦.基本原理就是在页面增加一个隐藏iframe,然后通过ajax提交除文件之外的表单数据,在表单数 ...
- OSS web直传 ajax方式 上传图片、文件
部分js代码 send_request = function(){//这是从后台获取认证策略等信息. var htmlobj=$.ajax({url:root+"/service/polic ...
- [转] 通过Ajax方式上传文件,使用FormData进行Ajax请求
通过传统的form表单提交的方式上传文件: <form id= "uploadForm" action= "http://localhost:8080/cfJAX_ ...
- 百度编辑器ueditor通过ajax方式提交,不需要事先转义字符的方法(异常:从客户端(xxx)中检测到有潜在危险的 Request.Form 值)
最近项目中使用百度编辑神器ueditor,确实是很好用的一款编辑器.官网教程提供的与后端数据交互都是跟表单方式有关的,项目中使用的是ajax方式提交,因此出现了不少问题,现在记录备忘下. 环境:.ne ...
- jquery.validate ajax方式验证
在做网站的时候有一块需要用到jquery.validate插件 ajax方式的方式来验证原始密码是否正确,研究了研究加上博客园朋友的帮助,终于实现了.贴出代码 <script type=&quo ...
- [实战]MVC5+EF6+MySql企业网盘实战(5)——ajax方式注册
写在前面 今天贴合到实际的客户需求仔细的想了下,其实在userInfo这个类里面很多字段都不是必须的.有很多的事业单位根本就不能上网,填写的邮箱也是exchange的,个人的详细信息都在ad里面可以取 ...
- python笔记-20 django进阶 (model与form、modelform对比,三种ajax方式的对比,随机验证码,kindeditor)
一.model深入 1.model的功能 1.1 创建数据库表 1.2 操作数据库表 1.3 数据库的增删改查操作 2.创建数据库表的单表操作 2.1 定义表对象 class xxx(models.M ...
- 阿里OSS ajax方式 web直传
部分js代码 send_request = function(){//这是从后台获取认证策略等信息. var htmlobj=$.ajax({url:root+"/service/polic ...
随机推荐
- oracle几个函数整理 DECODE() NVL NVL2 NULLIF Coalesce(转)
DECODE() decode()函数简介: 主要作用:将查询结果翻译成其他值(即以其他形式表现出来,以下举例说明): 使用方法: Select decode(columnname,值1,翻译值1,值 ...
- ios9基础知识(UI)总结
UIWindow.UILabel.UIColor.UIScreen.UIViewController.UIView.UIControl.UIButton.IBOutlet.IBAction.UISte ...
- REST总结
REST是Roy Thomas Fielding博士于2000年在他的博士论文中阐述的一种架构风格和设计原则.REST并非一种协议或者标准,事实上它只是阐述了HTTP协议的设计初衷:现在HTTP在网络 ...
- Q - 密码(第二季水)
Description 网上流传一句话:"常在网上飘啊,哪能不挨刀啊-".其实要想能安安心心地上网其实也不难,学点安全知识就可以. 首先,我们就要设置一个安全的密码 ...
- 垃圾回收器 Dispose 和 Finalize 的互补作用
假如我们程序有两个窗口 Form1.Form2; 当我们关闭一个窗口的时候,会发出一个 终止响应,并将该窗口对象送入终止队列,公共语言运行库的垃圾回收器跟踪着这个对象的生存期,此时就会调用此对象的基类 ...
- Android中使用开源框架android-image-indicator实现图片轮播部署
之前的博文中有介绍关于图片轮播的实现方式,分别为(含超链接): 1.<Android中使用ViewFlipper实现屏幕切换> 2.<Android中使用ViewPager实现屏幕页 ...
- 初识scrapy,美空网图片爬取实战
这俩天研究了下scrapy爬虫框架,遂准备写个爬虫练练手.平时做的较多的事情是浏览图片,对,没错,就是那种艺术照,我骄傲的认为,多看美照一定能提高审美,并且成为一个优雅的程序员.O(∩_∩ ...
- SQL Server 查看当前活动的锁
第一步: 要查看活动中的锁,如果日前根本就没有活动中的锁怎么办,还好我会自己做一把. begin tran select * from dbo.Nums with(ta ...
- webpack图片的路径与打包
转的http://www.cnblogs.com/ghost-xyx/p/5812902.html 今天写 react遇到打包图片,之前都是通过url在css里,没遇到问题,今天在 react里直接用 ...
- create custom launcher icon 细节介绍
create custom launcher icon 是创建你的Android app的图标 点击下一步的时候,出现的界面就是创建你的Android的图标 Foreground: ” Foregro ...