今天的主题是前端都了解的AJAX,但其中都有哪些知识点,还需要深入分析。

首先揭示AJAX的字面意思,Asynchronous Javascript And XML,通俗点就是“异步Javascript和XML”。

那有同步的吗?曾经的form提交并转到另一个页面刷新就是这种‘同步’的案例,有了AJAX后,便可以实现网页不提交(刷新)更新网页内容。

其实质便是依赖异步的Javascript请求网络,响应返回后,通过Javascript操作DOM接口更新HTML节点内容。

而这个能够实现异步的Javascript对象便是XMLHttpRequest。

真正实现异步的并不是XMLHttpRequest对象本身,而且浏览器内核会针对XHR对象的请求另起一个线程进行处理,处理完成后将回调对象放入JS队列。

下面介绍一些XMLHttpRequest对象的基本内容。

XMLHttpRequest对象在W3C标准下提供了很多属性。其中包括:

https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest

onreadystatechange 用于监听readyState状态变化

reponseText 响应返回文本

reponseXML   响应格式化为XML返回内容

status HTTP状态码

statusText HTTP状态码文本值

readyState XMLHttpRequest对象的状态

上述这些都是经常用到的属性,其中两个状态值再分类描述一下:

status:HTTP状态码

1xx:服务器临时响应

2xx:服务器成功响应

3xx:服务器重定向

4xx: 客户端请求错误

5xx: 服务器内部错误

readyState :

0:XMLHttpRequest对象已实例化,但未初始化open

1:对象已初始化open,但未send

2:对象已send,但status状态未知

3:对象已接收到部分数据

4:对象成功接收完成数据

通过上面介绍之后,我们可以利用XMLHttpRequest来实现一段异步请求并刷新局部页面的功能。

这里不考虑XMLHttpRequest在浏览器间的兼容性。

var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
if(xhr.readyState == 4 && xhr.state == 200){
handleHTML(xhr.responseText);
}
}
xhr.open('get', url, true);
xhr.send();

上例就是一个简单的XMLHttpRequest对象使用。还可以使用post方式实现类似form数据的提交。

var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
if(xhr.readyState == 4 && xhr.state == 200){
handle(xhr.responseText);
}
}
xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xhr.send("param1=1&param2=2");

上面是XMLHttpRequest Level 1的一些使用方式。虽然功能简单,但是解决了早期很多问题,主要包括:

1.XMLHttpRequest是异步的,请求无需等待,可以提供良好的体验;

2.无需刷新页面,可提高网页加在效率,降低服务器压力;

3.解决了以往需要依靠隐藏iframe实现异步请求的问题。

但是依然存在一些缺陷,比如:

1.受到同源策略的限制,无法实现跨域请求;

2.无法实现文件的上传及其进度;

3.无法获取服务器二进制数据;

4.自身不支持超时处理。

针对上述问题,Level 2还未出来前,前端一直采用特殊的作法,针对每一点:

1.采用JSONP,即<script>标签避开同源策略,实现跨域请求(JSOP知识点有可扩展空间)

2.未知

3.修改mimeType将二进制数据伪装成text,然后再代码中还原二进制数据(mimeType: 'text/plain; charset=x-user-defined')

4.添加setTimeout处理

但Level 2出来以后,上述这些问题都已解决,而且扩展了一下属性:

1.responseType/response,可支持二进制数据,ByteArray/Blob/File;

2.添加了xhr.upload对象,支持上传,还有progress事件可监听上传下载进度。

下面针对上传贴出一个小例子,在此基础上配合服务器编程可实现大文件断点续传。

var xhr = new XMLHttpRequest();
xhr.open('POST', url, true);
xhr.onload = function (e){
// 当前文件块上传完,可开始上传下一块
}
xhr.upload.onprogress = function(e){
// e.loaded 当前文件块上传字节数
// e.totalSize 当前文件块总字节数
}
// 可设置一定超时,如果超时可调节发次发送的文件块大小
xhr.send(trunck);

以上是对XMLHttpRequest对象的大概分析,其规范中包括大量属性和接口,请参考对应内容。

AJAX原理及XMLHttpRequest对象分析的更多相关文章

  1. Ajax技术---核心XMLHttpRequest对象

    Ajax 的全称是Asynchronous JavaScript and XML,其中,Asynchronous 是异步的意思,它有别于传统web开发中采用的同步的方式. (一)ajax技术的意义 我 ...

  2. Ajax中的XMLHttpRequest对象详解

    XMLHttpRequest对象是Ajax技术的核心.在Internet Explorer 5中,XMLHttpRequest对象以ActiveX对象引入,被称之为XMLHTTP,它是一种支持异步请求 ...

  3. ajax原理和XmlHttpRequest对象

    Ajax的原理简单来说通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,然后用javascript来操作DOM而更新页面.这其中最关键的一步就是从服务器获得请求数据.要清楚这 ...

  4. Ajax中的XMLHttpRequest对象详解(转)

    XMLHttpRequest对象是Ajax技术的核心.在Internet Explorer 5中,XMLHttpRequest对象以ActiveX对象引入,被称之为XMLHTTP,它是一种支持异步请求 ...

  5. $.ajax通用格式&&XMLHttpRequest对象属性和方法

    $.ajax({ url: "", type: "POST", async: false, cache:false, //默认true data: {}, da ...

  6. AJAX的核心XMLHttpRequest对象

    为了实现异步通讯,提高用户体验度,而将很多旧知识(XML,DOM,JavaScript,HTML,jQuery,Css...)重新融合程一个新的知识框架.而XMLHttpRequest对象则是其中的重 ...

  7. Ajax异步请求XMLHttpRequest对象Get请求

    $(function () { $("#btnGetDate").click(function () { var xhr; //第一步:创建异步请求的核心的对象: if (XMLH ...

  8. 原生Ajax XMLHttpRequest对象

    一.Ajax请求 - 现在常见的前后端分离项目中,一般都是服务器返回静态页面后浏览器加载完页面,运行script中的js代码,通过ajax向后端api发送异步请求获取数据,然后调用回调函数,将数据添加 ...

  9. AJAX 原理(转摘)

    在写这篇文章之前,曾经写过一篇关于AJAX技术的随笔,不过涉及到的方面很窄,对AJAX技术的背景.原理.优缺点等各个方面都很少涉及null.这次写这篇文章的背景是因为公司需要对内部程序员做一个培训.项 ...

随机推荐

  1. Find Minimum in Rotated Sorted Array

    package leetcode; /* * * 注意问题: * 1. 原序列升序.降序问题,两种情况都要考虑 * 2. 边界问题,如果只有两个元素时要单独考虑,在num[mid]==num[left ...

  2. while的使用

    我在用while的时候, while(当这个对象的首个字是汉字){ 执行语句 } 我发现出现死循环的现象 其实我要再添加一个条件,就是不管是不是上述条件都成立,最终还是要结束的.

  3. Fault Tolerance —— Storm的故障容错性

     ——本文讲解了Storm故障容忍性(Fault-Tolerance)的设计细节:当Worker.节点.Nimbus或者Supervisor出现故障时是如何实现故障容忍性,以及Nimbus是否存在单点 ...

  4. Zend studio 10.6 配置XDEBUG

    1. 查看PHP版本,下载XDebug     然后去网站http://xdebug.org/download.php下载相应的XDEBUG, 把下载好的文件放到相应的PHP下的EXT目录下,替换之前 ...

  5. spring aop两种配置方式(1)

    第一种:注解配置AOP注解配置AOP(使用 AspectJ 类库实现的),大致分为三步: 1. 使用注解@Aspect来定义一个切面,在切面中定义切入点(@Pointcut),通知类型(@Before ...

  6. hdu 2160 母猪的故事

    Problem Description 话说现在猪肉价格这么贵,著名的ACBoy 0068 也开始了养猪生活.说来也奇怪,他养的猪一出生第二天开始就能每天中午生一只小猪,而且生下来的竟然都是母猪.不过 ...

  7. topcoder SRM 610 DIV2 TheMatrix

    题目的意思是给一个01的字符串数组,让你去求解满足棋盘条件的最大棋盘 棋盘的条件是: 相邻元素的值不能相同 此题有点像求全1的最大子矩阵,当时求全1的最大子矩阵是用直方图求解的 本题可以利用直方图求解 ...

  8. 设置 tableview 的背景 颜色 和清空

    表示图中Cell默认是不透明的,那么在设置表示图的背景颜色和图片时通常是看不到的 1.给tableView设置背景view UIImageView *backImageView=[[UIImageVi ...

  9. 转自虫师:性能测试的 Check List

    原文地址:http://www.cnblogs.com/jackei/archive/2006/03/24/357372.html 1. 开发人员是否提交了测试申请? 2. 测试对象是否已经明确? 3 ...

  10. PHP面向对象学习三 类的抽象方法和类

    一个类中至少有一个方法是抽象的,我们称之为抽象类. 所以如果定义抽象类首先定义抽象方法. 1.类中至少有一个抽象方法 2.抽象方法不允许有{ } 3.抽象方法前面必须要加abstract 抽象类的几个 ...