| 网站首页 | 文章中心 | 电子书下载 | 矢量图库 | 视频教程 | 素材下载 | 程序代码下载 | JS代码 | 论坛 | 
常用软件类:
|杀毒安全 |联络聊天 |网络软件 |多媒体类 |系统工具 |图形图像 |系统工具 |应用软件 |行业软件
开发设计类:
|动画制作 |图像处理 |3D设计 |操作系统 |站长学院 |网络相关 |WEB设计 |数据库类 |程序开发
基于 Ajax 的无限级菜单
作者:佚名    文章来源:网络    点击数:    更新时间:2006-12-6
 

 
现在到处都有这方面的教程,我重点说一下我自己搞的一个框架。 
特点: 
支持Form的无闪提交(方法有点笨) 
支持MVC框架,即支持传统网页架构 
多线程并发请求(要语言支持线程) 
动态加载文件,只加载有用的!处理了Ajax框架臃肿的JS文件问题。 
采用no table的全div + css布局 
a. 获得XMLHTTPRequest对象,网上到处都找得到了,不多说: 
function newXMLHttpRequest() { 
var xmlreq = false; 
if (window.XMLHttpRequest) { 
xmlreq = new XMLHttpRequest(); 
} else if (window.ActiveXObject) { 
try { 
xmlreq = new ActiveXObject("Msxml2.XMLHTTP"); 
} catch (e1) { 
try { 
xmlreq = new ActiveXObject("Microsoft.XMLHTTP"); 
} catch (e2) { 



return xmlreq; 

这里提供一个通用的支持多浏览器的方法。 
b.提出异步请求 
//这里用Bcandy作为方法名是为了感谢一个对我来说很重要的人,她一直在支持我 
function Bcandy(Tid,url,parm,js) { 
if(url == ""){ 
return; 

//这是一个加载信息提示框,也可以不要! 
document.getElementById("load").style.visibility = "visible"; 
//加载相应页面的JS文件 
if(js != null){ 
//加载JS文件 
LoadJS(js); 

// 获取一个XMLHttpRequest实例 
var req = newXMLHttpRequest(); 
// 设置用来从请求对象接收回调通知的句柄函数 
var handlerFunction = getReadyStateHandler(req,Tid); 
req.onreadystatechange = handlerFunction; 
// 第三个参数表示请求是异步的 
req.open("POST", url, true); 
// 指示请求体包含form数据 
req.setRequestHeader("Content-Type", 
"application/x-www-form-urlencoded"); 
// 发送参数 
req.send(parm); 

function getReadyStateHandler(req,Tid) { 
// 返回一个监听XMLHttpRequest实例的匿名函数 
return function () { 
// 如果请求的状态是“完成” 
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("HTTP error: "+req.status); 




//动态加载JS文件 
function LoadJS(file){ 
var head = document.getElementsByTagName(’HEAD’).item(0); 
var script = document.createElement(’SCRIPT’); 
script.src = file; 
script.type = "text/javascript"; 
head.appendChild(script); 

这就是基本的框架了,因为使用了request.responseText;所以,可以直接请求一个页面jsp,servlet但在使用Struts框架的请求时要进行特殊处理,因为Form不支持异步请求。建议在这些页面上不要加入标签,就像.net里的asxm文件!而且在使用Struts框架时有点要注意的是,Mapping对象直接返回null就可以了,因为我们会在下面讲到并发多线程。来处理这个问题的。 
总的来看,有点像是积木搭建起来的。这样方便文件的修改和扩展,互相之间并不影响,而且,实现了代码和标签分离。在进行传统页面改版时,也不用重新编写全部代码。只要修改一小部分就可以完美实现Ajax带来的无闪刷新快感。 
以上代码均在IE,FireFox下测试过!

[1] [2] 下一页


相关文章