前沿:对于此篇随笔,完是简要写了几个重要的地方,具体实现细节完在提供的源码做了笔记

<一>ajax基本要点介绍--更好的介绍ajax

1. ajax对象中new XMLHttpRequest()属性和方法列表

2. 常用事件介绍

事件 触发时机
onreadystatechange 当readyState的值改变时触发,除了当它从非0变成0时
onloadstart 当调用send方法时会触发xhr.onloadstart,然后会触发xhr.upload.onloadstart,代表开始上传数据
onprogress 上传数据过程中会触发xhr.upload.onprogress,下载数据过程中会触发xhr.onprogress,onprogress每50ms会触发一次
onabort 调用abort方法后会触发
onerror 当发生网络异常的时候会触发,如果上传数据的过程还未结束,此时会先触发xhr.upload.onerror,然后再触发xhr.onerror;如果上传数据的过程已经结束,此时只会触发xhr.onerror
onload 上传数据成功,会触发xhr.upload.onload;下载数据成功会触发xhr.onload
ontimeout 当服务端响应的时间超过指定的timeout时间时,会触发此事件
onloadend 上传数据完成(成功或者失败)时会触发xhr.upload.onloadend;下载数据完成(成功或失败)会触发

3. 请求开始和结束零界点

【3.1】请求开始

  xhr.onloadstart事件触发的时候,也就是你调用xhr.send()方法的时候。
因为xhr.open()只是创建了一个连接,但并没有真正开始数据的传输,而xhr.send()才是真正开始了数据的传输过程。只有调用了xhr.send(),才会触发xhr.onloadstart 。

【3.2】请求结束

  xhr.loadend事件触发的时候

备注:

  a.可以在 send()之后再设置此xhr.timeout,但计时起始点仍为调用xhr.send()方法的时刻。

  b.当xhr为一个sync同步请求时,xhr.timeout必须置为0,否则会抛错。原因可以参考本文的【如何发一个同步请求】一节。

4. 具体实现细节--封装ajax

function _ajax(obj){
var xhr = null;
// 创建-非IE6 : IE6及其以下浏览器
if(window.XMLHttpRequest){
xhr=new XMLHttpRequest();
//针对某些特定版本的Mozillar浏览器的BUG进行修正
if(xhr.overrideMimeType) {
xhr.overrideMimeType("text/xml");
}
}else if(window.ActiveXObject){
var arr = ['MSXML2.XMLHTTP', 'Microsoft.XMLHTTP'];
for(var i = 0; i < arr.length; i++){
try {
xhr = new ActiveXObject(arr[i]);
break;
}catch (e){
console.log(e);
}
}
} // 默认是异步请求
var asyc = obj.asyc || true;
var type = obj.type.toUpperCase() || "GET";
var url = obj.url;
var data = obj.data || {}; console.log(objToStr(data)); //选择发送请求方式
if(type === "GET"){
xhr.open(type,url+'?'+objToStr(data),asyc);
xhr.send();
}else if(type === "POST"){
xhr.open(type,url,asyc);
// 告诉后台传的是什么
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
// xhr.setRequestHeader('Last-Modified', 'faqenfaAWASVaewfc');
xhr.send(objToStr(data));
} // 设置超时请求时间
xhr.timeout = 3000; // 发送异步回调函数
xhr.onreadystatechange = function () {
console.log(xhr.readyState);
// 测试追踪ajax处于那种状态,在正式代码中要隐藏此switch
switch (xhr.readyState){
case 0:
console.log('xhr对象被成功构造,open()方法还未被调用');
break;
case 1:
console.log('open()方法已被成功调用,send()方法还未被调用');
break;
case 2:
console.log('send()方法已经被调用, 响应头和响应状态已经返回');
break;
case 3:
console.log('响应体(response entity body)正在下载中,此状态下通过xhr.response可能已经有了响应数据');
break;
case 4:
console.log('整个数据传输过程结束,不管本次请求是成功还是失败');
break;
} if(xhr.readyState === 4 && xhr.status === 200){
obj.success(xhr.responseText)
}else {
obj.error && obj.error();
}
}; // 请求开始
xhr.onloadstart = function (e) {
console.log(e,'start');
}; //ajax请求结束
xhr.loadend = function (e) {
console.log(e,'end');
}; // 超时函数处理
xhr.ontimeout = function (e) {
obj.timeout && obj.timeout();
console.log(e,'timeout');
}; // ajax请求错误处理
xhr.onerror = function (e) {
obj.errorAsyc && obj.errorAsyc();
console.log(e,'error');
}; // 上传进度处理--upload用于在数据传输到服务器时收集一些传输信息,比如上传了多少字节,总共多少字节等,其里面还包含了一些事件回调
xhr.upload.onprogress = function (e) {
obj.progress && obj.progress();
console.log(e,'progress');
}; console.log(xhr.getAllResponseHeaders(),'0000');
// 把对象转换成字符串
function objToStr(obj) {
var arr = [];
for(var key in obj){
arr.push(key+'='+obj[key])
}
return arr.join('&');
}
}

【封装ajax调用方式】

   window.onload = function () {
btn.onclick= function () {
_ajax({
url:'http://localhost:8800',
type:'post',
asyc:true, //默认是true
data:{
username:'zhange',
password:'123456'
},
success:function (data) {
console.log(data);
},
error:function () { }
});
}
};

原生ajax解析&封装原生ajax函数的更多相关文章

  1. 原生ajax与封装的ajax使用方法

    当我们不会写后端接口来测试ajax时,我们可以使用node环境创建一个本地服务器. 1.创建一个本地服务器可参考http://www.cnblogs.com/heyujun-/p/6793900.ht ...

  2. js实现原生Ajax的封装及ajax原理详解

    原理及概念 AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是一种用于创建快速动态网页的技术. 动态网页:是指可以通过服务器语言结合数 ...

  3. Ajax的封装,以及利用jquery的ajax获取天气预报

    1.Ajax的封装 function ajax(type,url,param,sync,datetype,callback){//第一个参数是获取数据的类型,第二个参数是传入open的url,第三个是 ...

  4. 原生实现ajax解析--XMLHttpRequest

    ajax基础: Asynchronous JavaScript and XML,意思就是用JavaScript执行异步网络请求. 如果仔细观察一个Form的提交,你就会发现,一旦用户点击“Submit ...

  5. js原生Ajax 的封装和原理

    原理及概念 AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是一种用于创建快速动态网页的技术. 动态网页:是指可以通过服务器语言结合数 ...

  6. 原生封装的ajax

    原生封装的ajax的代码如下: //将数据转换成 a=1&b=2格式; function json2url(json){ var arr = []; //加随机数防止缓存; json.t = ...

  7. js原生Ajax的封装与使用

    一.原生Ajax代码的封装如下: (function() { var XHR = { createStandardXHR: function() { return new XMLHttpRequest ...

  8. JavaScript的原生Ajax解析

    通过JavaScript的Ajax进行详细的解析过程,从而更好的了解Jquery的Ajax. 顺带,我会在后面把我整理的一整套CSS3,PHP,MYSQL的开发的笔记打包放到百度云,有需要可以直接去百 ...

  9. javascript - 封装原生js实现ajax

    1 /* * ajax方法 */ var Ajax = function() { var that = this; //创建异步请求对象方法 that.createXHR = function() { ...

随机推荐

  1. shell基础知识8-xargs命令

    简介 xargs 命令应该紧跟在管道操作符之后.它使用标准输入作为主要的数据源,将从 stdin 中 读取的数据作为指定命令的参数并执行该命令. 将多行输入转换成单行输出 [root@dns-node ...

  2. qt model/view/delegate

    Qt Model/View理解(一)---构造model https://blog.csdn.net/weixin_42303052/article/details/89233887 Qt Model ...

  3. linux install jsoncpp0.5.0

    要安装jsoncpp,首先要下载好scons,再去安装jsoncpp scons下载地址:wget http://prdownloads.sourceforge.NET/scons/scons-2.2 ...

  4. 基于面绘制的MC算法以及基于体绘制的 Ray-casting 实现Dicom图像的三维重建(python实现)

    加入实验室后,经过张老师的介绍,有幸与某公司合共共同完成某个项目,在此项目中我主要负责的是三维 pdf 报告生成.Dicom图像上亮度.对比度调整以及 Dicom图像三维重建.今天主要介绍一下完成Di ...

  5. Linux内核--伙伴系统--页释放

    本文转载自:http://www.cnblogs.com/tolimit/ 感觉原博分析的不错,借花献佛. ---------------------------------------------- ...

  6. 1. Spark GraphX概述

    1.1 什么是Spark GraphX Spark GraphX是一个分布式图处理框架,它是基于Spark平台提供对图计算和图挖掘简洁易用的而丰富的接口,极大的方便了对分布式图处理的需求.那么什么是图 ...

  7. Mysql的常见索引

    PRIMARY KEY(主键索引) ALTER TABLE table_name ADD PRIMARY KEY ( col ) 它是一种特殊的唯一索引,不允许有空值: UNIQUE(唯一索引) AL ...

  8. 阿里云负载均衡SLB上用免费的Let's Encrypt的SSL证书

    Let's Encrypt是很火的一个免费SSL证书发行项目,自动化发行证书,证书有90天的有效期.Let's Encrypt已经发布了工具certbot,用此工具生成证书.证书续期非常简单. 以下是 ...

  9. C# vb .net实现胶片效果滤镜

    在.net中,如何简单快捷地实现Photoshop滤镜组中的胶片效果呢?答案是调用SharpImage!专业图像特效滤镜和合成类库.下面开始演示关键代码,您也可以在文末下载全部源码: 设置授权 第一步 ...

  10. C# vb .net实现淡出效果特效滤镜

    在.net中,如何简单快捷地实现Photoshop滤镜组中的淡出效果特效呢?答案是调用SharpImage!专业图像特效滤镜和合成类库.下面开始演示关键代码,您也可以在文末下载全部源码: 设置授权 第 ...