AJAX分段下载/读取HTML内容(有效节省带宽加快运行速度)
来源:互联网 发布:wd移动硬盘格式化mac 编辑:程序博客网 时间:2024/05/16 08:40
本来以为自己已经算是对AJAX技术了如指掌了,因为从3年前就一直用XMLHttpRequest对象做一些无刷新页面的处理工作,但是,直道今天在工作中遇到了一个分段读取内容的问题,我才了解到,自己原来还需要补充。
基本的问题是这样的:
我需要设计一个框架,需要承载500万以上用户访问(公司毕竟是中国用户最多的互联网企业)。我们用了大量的静态化技术,为了应对可能出现的高负载,我们还是用了一些公司内自主研发的高性能静态WEB服务器。由于页面是静态生成的,我们遇到一个问题,就是如何在某一时刻更新了某个静态文件后,在前台进行AJAX的加载。起初对这个问题想得比较简单,认为只要加载然后赋值并显示即可,但是在以前血的教训下(当加载的内容非常大,IE浏览器渲染显示的时候会非常慢,给用户明显的跳动刷新的感觉。),我们决定对于文件进行分段加载,这样做不但解决了一次加载过大文件的问题,同时也为服务器省下了一些处理时间和资源,尽可能快地结束HTTP请求。
解决方案:
我拿到这个问题,在设计的过程中首先考虑的是,分段请求应该就是类似于FlashGet之流,进行分段请求而已,只需要构造自己的HTTPRequest请求的Headers就能够达到目的,因为对HTTP协议还算是比较熟悉,所以我的分析应该是没错,如果是在.net中,我会毫不犹豫地利用WebHttpRequest()进行请求的封装,通过设置Range字段来实现上述的功能,但是,问题是在静态页面的JS里面利用XMLHttpRequest来实现,就有一定的难度了,毕竟从来没有接触过。查阅了大量的资料后发现,在XMLHttpRequest里面确实可以设置SetHeader(),最终决定使用Prototype.js里面现成的封装来实现,具体实现如下——
<script language="javascript">
//alert($("Shadow").innerHTML);
var myarray = new Array();
myarray.push("Range");
myarray.push("bytes=0-");
myarray.push("Pragma");
myarray.push("no-cache");
myarray.push("Cache-Control");
myarray.push("no-cache");
alert(myarray[1].toString());
function myAJAX(){
new Ajax.Request('replace.php', {
method:'get',
requestHeaders:myarray,
onSuccess: function(transport){
var json = transport.responseText;//.evalJSON();
alert(json);//.a);
//var data = '{ "name": "Violet", "occupation": "character" }'.evalJSON();
//alert(data.name);
}
});
}
</script>
为了测试,我使用Array.push()方法建立数组,没有直接初始化数组,一段儿测试代码大家将就看看,我说一下比较重要的几点:
1、Prototype里面RequestHeaders是一个数组,作为参数的内容必须是个数组;
2、Prototype里面这个参数是可选得;
3、Prototype里调用Ajax.Request()的时候加参数的方法和其他参数一样——“requestHeaders:myarray,”参数用逗号分割。
4、Prototype里设置分段的方法如下——
Range头域可以请求实体的一个或者多个子范围。例如,
表示头500个字节:bytes=0-499
表示第二个500字节:bytes=500-999
表示最后500个字节:bytes=-500
表示500字节以后的范围:bytes=500-
第一个和最后一个字节:bytes=0-0,-1
同时指定几个范围:bytes=500-600,601-999
GEThttp://download.microtool.de:80/somedata.exe
Host:download.microtool.de
Accept:*/*
Pragma:no-cache
Cache-Control:no-cache
Referer:http://download.microtool.de/
User-Agent:Mozilla/4.04[en](Win95;I;Nav)
Range:bytes=554554-
以上是一个测试的头,注意Range字段!
前段时间跳槽了,所以很久没来写文章,现在压力很大啊,感觉这么大个项目自己要亲自去设计,还是蛮有压力的,只能努力工作、祝自己好运了!在工作中如果发现什么觉得有价值的技巧,我会在这里跟大家进行分享。
- AJAX分段下载/读取HTML内容(有效节省带宽加快运行速度)
- 怎么有效的节省资源加快访问站点速度?
- 图片的预先读取-加快下载速度
- XP怎样节省内存,加快开机速度
- 下载速度/带宽 换算
- 加快计算机运行速度
- c#加快读取图片速度
- 带宽下载速度单位换算
- 关于带宽与下载速度
- 宽带带宽和下载速度
- VS2010 运行速度加快方法
- VS2010 运行速度加快方法
- 加快系统的运行速度
- VS2010 运行速度加快方法
- VS2010运行速度加快方法
- VS2010 运行速度加快方法
- 加快VS2010 运行速度方法
- VS2010 运行速度加快方法
- symbian rsocket 的一个例子
- Qt资源
- 顺序表实现(SeqList C++)
- zoj 1111 Poker Hands
- java截取带html标签的字符串,再把标签补全(保证页面显示效果)
- AJAX分段下载/读取HTML内容(有效节省带宽加快运行速度)
- jquery 刷新页面方法和一些javascript基础函数
- 模块文件生成html
- POJ 1740 A New Stone Game
- ASP录入的内容生成静态html
- Wcf Ria Services学习笔记(四):WCF RIA Service中的增删改查操作
- 优秀的web应用
- vim折叠
- 酷派768