1.建立兼容性强的XHR对象有那么复杂么?

看过一些书,书上为了写针对低版本IE和其他非IE浏览器需要写一大串兼容函数,典型的就是JS高级程序上的。

可是在现实开发中,为了兼容IE6/IE7,只需要这样创建一个XHR对象: var XHR=new ActiveXObject('Microsoft.XMLHTTP');就足够了。

而IE8以上是支持XMLHttpRequest对象的。

2.ajax修改HTTP请求头和获取HTTP响应头

无论是ActiveX对象还是XMLHttpRequest对象,都会支持以下几种方法:

xhr.setRequestHeader('key','value');

xhr.getResponseHeader('key');

xhr.getAllResponseHeaders();

区分一下:在xhr对象的方法中,我们只能设置http请求头,而不能获取http请求头。相反:我们只能获取响应头,而不能设置响应头。(原因嘛,稍微有点BS常识的人都知道)

不过这三种方法中常用的只有setRequestHeader方法,可以用来设置请求报头,典型的就是GET请求缓存和post方式模拟提交表单数据的请求,必须需要设置http响应头的Control-Type属性值为:application/x-www-form-urlencoded,而设置头的顺序也是有讲究的,1.先open 2.设置头 3.再send(data); 否则会报 ‘未指明错误’ 的异常

剩下的两种,除非你要做响应进度条,否则没啥用(至少初级水平的前端开发人员在大多数情况下是用不到的)。利用的是响应头中的Content-length

3.ajax的CORS策略

所谓的CORS其实就叫跨域资源共享,说白了就是Ajax跨域。

ajax跨域不是剃头挑子一头热就能解决的,肯定需要目标资源那边的服务器支持,否则无法达成跨域

设置响应报头方法

js高级程序设计上说的很清楚,我只是简单的提一下:

不同域服务器要做的事:给HTTP的响应报头添加如下属性: Access-Control-Allow-Origin:ajax请求域域名

发起ajax请求域要做的事:XMLHttpRequest已经支持了对不同域资源的解析,所以这边我们不需要做什么改动。至于ActiveObject,由于我在用两个同域名不同端口的VS2010项目做的实验,即使不设置响应头也能“跨域”,所以现在不确定。

综合上述提到得内容,我们可以编写一个通用的ajax方法:

function ajax(url, method, funcSucc, funcFail, data, contentType) {
var xhr = null;
if (window.ActiveXObject) {
xhr = new ActiveXObject('Microsoft.XMLHttp');
}
else {
xhr = new XMLHttpRequest();
} if (data) {
if (method == 'post' || method == 'POST') {
xhr.open(method, url, true);
try{
xhr.setRequestHeader('Content-Type', contentType);
}
catch (e) {
alert(e);
}
}
else {
var arr = url.split('?');
if (arr[1]) {
url = arr[0] + '?' + arr[1] + '&' + +data;
}
else {
url += '?' + data;
}
xhr.open(method, url, true);
}
} xhr.onreadystatechange = function () {
if (xhr.readyState == 4) {
if (xhr.status == '200') {
if (funcSucc) {
funcSucc(xhr.responseText);
}
else {
return xhr.responseText;
}
}
else {
if (funcFail) {
funcFail();
}
else {
alert('错误状态:' + xhr.status);
}
}
}
}
if (method == 'post' || method == 'POST') {
xhr.send(data);
}
else {
xhr.send(null);
}
}

 4.如何提升ajax的性能

 a.设法缓存请求到得responseText

方法有两种:1是设置请求报头,添加 Expires字段的过期时间,时间格式是格林尼治时间。而且只适用于get方法的请求;

2是设置本地缓存,用全局对象存储responseText,这种方法比较简单,而且适用于移动端。

b.将数段内容的responseText分段处理

通过判断xhr对象的readyState==3时的状态,可以一段一段的获取responseText,这样可以避免处理长的回文。

req.onreadystatechange = function() {
if (req.readyState === 3) { // 只有当二次请求之后的所有请求的状态为3时,才能获取上次请求发回的responseText,这里是对上次的处理.
var dataSoFar = req.responseText;
...
}
else if (req.readyState === 4) { // 又一段请求回文被获取
var data = req.responseText;
...
}
}

c.回文类型的选择

建议选用jsonp方式处理请求,或者自定义回文结构类型。jsonp的方式使得回文内容被当做JavaScript对象处理,省去了对象转换的繁琐。而自定义回文结构,则可以用更好的解析方法解析responseText;

再深入一点ajax的更多相关文章

  1. Android图表库MPAndroidChart(七)—饼状图可以再简单一点

    Android图表库MPAndroidChart(七)-饼状图可以再简单一点 接上文,今天实现的是用的很多的,作用在统计上的饼状图,我们看下今天的效果 这个效果,我们实现,和之前一样的套路,我先来说下 ...

  2. 前端通信:ajax设计方案(八)--- 设计请求池,复用请求,让前端通信快、更快、再快一点

    直接进入主题,本篇文章有点长,包括从设计阶段,到摸索阶段,再到实现阶段,最后全面覆盖测试阶段(包括数据搜集清洗),还有与主流前端通信框架进行对比PK阶段. 首先介绍一下一些概念: 1. 浏览器的并发能 ...

  3. 再谈Jquery Ajax方法传递到action 【转载】

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://cnn237111.blog.51cto.com/2359144/984466 之 ...

  4. 再谈Jquery Ajax方法传递到action

     原始出处 :http://cnn237111.blog.51cto.com/2359144/984466  本人只是转载 原文如下: 假设 controller中的方法是如下: public Act ...

  5. 再谈Jquery Ajax方法传递到action(转)

    之前写过一篇文章Jquery Ajax方法传值到action,本文是对该文的补充. 假设 controller中的方法是如下: public ActionResult ReadPerson(Perso ...

  6. 让小区运营再智能一点,EasyRadius正式向WayOs用户提供到期弹出式提示充值页面

    其实一直没向用户提供到期弹出式页面,主要是给VIP群的用户一点优越感,随着这次EasyRadius的更新,海哥就免费向普通easyRadius用户提供这两个模板下载. 有些人会问,什么样的模板.有什么 ...

  7. hdf第一周完了,突然时间静止.,醒了就早点去公司上班,再努力一点

    周一要了个任务,做评价完成,分享完成的页面,做到周四发现可能做不出来,找dzy,逻辑比较混乱,想要放弃了,感觉自己非常没用.昨天跟豆聊了一下,否定自己是一点意义也没有的,觉得自己很差劲,无助的感觉跟初 ...

  8. 技术再深入一点又何妨?一脸懵B的聊Actor

    记得上次深入 Resin 源码时,见到了Actor 字眼,当时主要从 Resin 中抽取关键架构,就屏蔽了 Actor 相关代码.未曾想这两天研究 flink 的运行架构以及源码,再次与 Actor ...

  9. 再深入一点|binlog和relay-log到底长啥样?

    上一篇mysql面试的文章之后收到不少朋友的意见,希望深入讲讲复制.日志的格式这些,今天,我们就来深挖一下mysql的复制机制到底有哪一些,以及binlog和relay-log的结构到底是什么样子的. ...

随机推荐

  1. openstack的控制节点部署

    openstack的控制节点部署 主要是使用了本地安装的那个镜像. 会出现几个问题, 1.重启服务无法启动. 2.环境变量无法正确配置可以自己配置

  2. spring aop 使用注解方式总结

    spring aop的注解方式:和xml的配置方式略有区别,详细如下: 1.首先还是建立需要的切面类:切面类里面定义好切点配置,以及所有的需要实现的通知方法. /** * */ package com ...

  3. orcle 查询数据集对变量赋值函数

    create or replace function test(Name in varchar2 ) return varchar2 is V_CONTAINERDESC CHAR ); BEGIN ...

  4. Objective-C 编码规范

    Objective-C 编码规范,内容来自苹果.谷歌的文档翻译,自己的编码经验和对其它资料的总结. 概要 Objective-C 是一门面向对象的动态编程语言,主要用于编写 iOS 和 Mac 应用程 ...

  5. centos6.3编译安装Apache2.4.3+PHP5.4.8+Mysql5.5.8

    以虚拟机VirtualBox 版本是4.1.20(内存设置为512M,centos安装是文本模式下安装),全新以最小化包安装了32位的 CentOS6.3系统,作为本地web环境,上次讲了在windo ...

  6. Python实现Apriori

    Python实现Apriori 运行环境 Pyhton3 计算过程 st=>start: 开始 e=>end: 结束 op1=>operation: 读入数据 op2=>ope ...

  7. Android实现SQLite数据库联系人列表

    Android实现SQLite数据库联系人列表 开发工具:Andorid Studio 1.3 运行环境:Android 4.4 KitKat 工程内容 实现一个通讯录查看程序: 要求使用SQLite ...

  8. VDN For PB Web实现消息推送

    利用VesnData.Net(VDN)的互联网数据驱动功能我们实现了PB连接互联网数据库的功能.在互联网开发的过程中我们往往有些消息或者数据希望即时能够通知到各个客户端,现在比较流行的一种技术就是消息 ...

  9. Unity3D定制新建C#文件的头描述

    1. 修改模板内容如下: MAC:Unity.app/Contents/Resources/ScriptTemplates/81-C# Script-NewBehaviourScript.cs.txt ...

  10. cocos2dx 2.0+ 版本,IOS6.0+设置横屏

    使用cocos2dx 自带的xcode模板,是不能正常的设置为横屏的. 一共修改了三个地方: 在项目属性中:Deployment Info中,勾选上 Landscape left,以及 Landsca ...