基于Ajax的无限级菜单
支持MVC框架,即支持传统网页架构
多线程并发请求(要语言支持线程)
动态加载文件,只加载有用的!处理了Ajax框架臃肿的JS文件问题。
采用notable的全div+css布局
varxmlreq=false;
if(window.XMLHttpRequest){
xmlreq=newXMLHttpRequest();
}elseif(window.ActiveXObject){
try{
xmlreq=newActiveXObject("Msxml2.XMLHTTP");
}catch(e1){
try{
xmlreq=newActiveXObject("Microsoft.XMLHTTP");
}catch(e2){
}
}
}
returnxmlreq;
}
这里提供一个通用的支持多浏览器的方法。
functionBcandy(Tid,url,parm,js){
if(url==""){
return;
}
//这是一个加载信息提示框,也可以不要!
document.getElementById("load").style.visibility="visible";
//加载相应页面的JS文件
if(js!=null){
//加载JS文件
LoadJS(js);
}
//获取一个XMLHttpRequest实例
varreq=newXMLHttpRequest();
//设置用来从请求对象接收回调通知的句柄函数
varhandlerFunction=getReadyStateHandler(req,Tid);
req.onreadystatechange=handlerFunction;
//第三个参数表示请求是异步的
req.open("POST",url,true);
//指示请求体包含form数据
req.setRequestHeader("Content-Type",
"application/x-www-form-urlencoded");
//发送参数
req.send(parm);
}
//返回一个监听XMLHttpRequest实例的匿名函数
returnfunction(){
//如果请求的状态是“完成”
if(req.readyState==4){
//成功接收了服务器响应
if(req.status==200){
//下面一句是重点,这里显示了返回信息的内容部分,也可以加以修改。进行其它处理
document.getElementById(Tid).innerHTML=req.responseText;
document.getElementById(Tid).style.visibility="visible";
//这一句是实现加载信息提示框的隐藏,也可以不要。
document.getElementById("load").style.visibility="hidden";
}else{
//有HTTP问题发生
document.getElementById("load").style.visibility="hidden";
alert("HTTPerror:"+req.status);
}
}
}
}
//动态加载JS文件
functionLoadJS(file){
varhead=document.getElementsByTagName("HEAD").item(0);
varscript=document.createElement("SCRIPT");
script.src=file;
script.type="text/javascript";
head.appendChild(script);
}
这就是基本的框架了,因为使用了request.responseText;所以,可以直接请求一个页面jsp,servlet但在使用Struts框架的请求时要进行特殊处理,因为Form不支持异步请求。建议在这些页面上不要加入<html><body>标签,就像.net里的asxm文件!而且在使用Struts框架时有点要注意的是,Mapping对象直接返回null就可以了,因为我们会在下面讲到并发多线程。来处理这个问题的。
总的来看,有点像是积木搭建起来的。这样方便文件的修改和扩展,互相之间并不影响,而且,实现了代码和标签分离。在进行传统页面改版时,也不用重新编写全部代码。只要修改一小部分就可以完美实现Ajax带来的无闪刷新快感。
以上代码均在IE,FireFox下测试过!
相关文章
- Java项目毕业设计:基于springboot+vue的电影视频网站系统「建议收藏」
- 什么是Ajax以及ajax请求的步骤[通俗易懂]
- AJAX读音_ajax怎么发音
- Ajax教程_ajax是服务器端动态网页技术
- spring ajax 长轮询,Ajax轮询和长轮询
- 使用AJAX时候,你可能没有想过他的背景技术详解编程语言
- Ajax注册MySQL极速轻量注册引擎(ajax注册mysql)
- MySQL与Ajax的联动大大提高网站数据交互的效率(ajax和mysql连用)
- 展现灵活性Ajax与MySQL的交互(ajax与mysql交互)
- AJAX技术简化Oracle数据库的访问处理(ajax连接oracle)
- 异步Ajax与Oracle数据库实现无缝连接(ajax连接oracle)
- Ajax超时检查脚本
- 基于AJAX的分页类实现代码
- Ajax+Json级联菜单实现代码
- JQuery运用ajax注册用户实例(后台asp.net)
- 基于asp+ajax和数据库驱动的二级联动菜单
- jQuery.ajax用户登录验证代码
- ajax更新数据后,jquery、jq失效问题
- ajax传递多个参数具体实现
- Ajax异步提交表单数据的说明及方法实例
- AJAX解析XML实例之下拉框省、市二级联动
- js每隔5分钟执行一次ajax请求的实现方法
- Ajax提交与传统表单提交的区别说明
- Ajax给XMLHttpReq.onreadystatechange传递参数
- Jquery基于Ajax方法自定义无刷新提交表单Form实例
- 基于Jquery+Ajax+Json实现分页显示附效果图