都知道实现页面的异步操作需要使用Ajax,那么Ajax到是怎么实现异步操作的呢?

首先需要认识一个对象 --> XMLHttpRequest 对象 --> Ajax的核心。它有许多的属性和方法事件以便于脚本处理和控制HTTP的请求和响应。

下面来认识几个属性:我不用官方的话来解释,希望大家能一看就知道是什么意思

  readyState 属性

    创建XMLHttpRequest对象(下面称ajax对象)后,readyState属性则表示当前对象处于一个什么状态 ,一共5个状态

    0   未初始化状态 ,ajax对象已经创建

    1   准备发送状态,调用了open()方法,并且已经准备好将一个请求发送到服务器

    2   已发送状态,   已经通过send()方法把一个请求发送到服务器,但是没有收到一个响应

    3   正在接受状态,已经接收到HTTP的响应头部信息,但是消息体还没有还没有完全接收

    4   完成响应状态,已经完成HttpResponse的响应接收

   status 属性:

    描述了HTTP状态代码,当readyState值小于3时 不可读取,会引发异常错误

下面是Ajax的封装代码,我们来逐步分析,以便于理解

 //把传进来的json格式转换url
function json2Url(json){
var arr = [];
json.t = Math.random();//添加随机时间,兼容ie
for(var name in json ){
arr.push(encodeURIComponent(name)+'='+encodeURIComponent(json[name]));
}
return arr.join('&');//转成url格式
};
//创建ajax函数
function ajax(json){
var timer = null;//定时器
//判断是否有url
if (!json.url) {
alert('没有url');
return;
}
// 创建ajax对象
if (window.XMLHttpRequest) {
var oAjax = new XMLHttpRequest();
}else{
var oAjax = new ActiveXObject('Microsoft.XMLHTTP');
} //数据赋值以及默认值
json.data = json.data || {}; //url ->?后面wd=a&json=1这个格式
json.time = json.time || 5000; //5秒后超时
json.asyn = json.asyn || true; //默认异步
json.type = json.type || 'GET';//默认GTE //提交方式判断
switch(json.type.toUpperCase()){
case 'GET':
oAjax.open('GET',json.url+'?'+json2Url(json.data),json.asyn);
oAjax.send(null);
break; case 'POST':
oAjax.open('POST',json.url,json.asyn);
oAjax.setRequestHeader('Content-type','application/x-www/form-urlencoded');
oAjax.send(json2Url(json.data));
break;
} //判断ajax是否已经完成响应
oAjax.onreadystatechange = function(){
if (oAjax.readyState == 4) {//ajax的状态是否已经完成响应
if (oAjax.status == 200 ) { //成功状态码
json.success && json.success(oAjax.responseText);
clearInterval(timer);
}else{
json.error && json.error(oAjax.status);
clearInterval(timer);
}
}
};
//设置超时
timer = setTimeout(function(){
alert('请求网络超时');
json.complete && json.complete();
oAjax.readystatechange = null;
},json.time);
}

1 .一个json2Url格式的方法

调用ajax()时里面是以json的形式传数据,但是我们的url是这样的

https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=&json=1&p=3&sid=1464_21105_18560_17001_;

所以我们需要把格式转换这样才能提交,由于ie存在缓存所以需要加一个随机数,encodeURIComponent()用来转码

2 创建ajax函数

3 判断传进来的数据中是否有url,如果没有url这直接return 并给一个提示

4 创建 XMLHttpRequest 对象,因为ie和其他浏览器不同,它是ActiveXObject对象所以我们来做一个兼容性封装

5 对 数据就行赋值以及添加默认值

6 判断提交方法,get 或者是post 按照规范最大最后转成大写

  get方式,数据都在url中,所以send()中是空的写null 或者不写都可以

  post方式,则需要设置一个请求头来表明你的内容格式,数据随着send()方法发送

7判断ajax是否响应完成,并判断HTTP的状态 码,根据状态码来决定执行函数

  onreadystatechange事件:每当readyState值发生变化值都会触发这个事件,可以理解它可以监听ajax

8 超时响应 ,超时给个回调函数,用了提高用户体验,并让readystatechange 等于null

 

总结起来的话:封装ajax ,你需要了解它的5个状态

       正在去做封装那么就记住上述8个步骤 ,我分的比较细以便于理解。如果去掉零碎部分大致可以分为下面5步

       1 创建XMLHttpRequest对象                    -->oAjax

       2 数据赋值及默认值                                 -->json.data = json.data || {}

       3 判断提交方式 get 或者post                    -->switch(json.type.toUpperCase())

       4 使用onreadystatechange事件 监听ajax   -->oAjax.onreadysatechange = function(){}

       5 超时处理                                            -->setTimeout()

记住这5步 就差不多了,具体怎么分看个人情况吧,最重要是理解

Ajax实现原理,代码封装的更多相关文章

  1. ajax请求原理及jquery $.ajax封装全解析

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

  2. Ajax原理与封装详解

    Ajax大家每天都在用,jquery库对Ajax的封装也很完善.很好用,下面我们看一下他的内部原理,并手动封装一个自己的Ajax库. 更多有关ajax封装及数据处理,请参看上海尚学堂<Ajax中 ...

  3. Ajax工作原理和原生JS的ajax封装

    前言: 之所以用ajax作为博客的开篇,是因为无论从ajax的出现还是从它的作用上来说,ajax对于前端无疑是意义重大的.甚至可以说,是ajax带来了前端这个行业.当然,历史并不能说明当下,曾经的辉煌 ...

  4. ajax原理及封装

    一:AJAX 简介 AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术,通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新. AJAX = 异步 JavaScri ...

  5. Ajax工作原理

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

  6. 关于Ajax工作原理

    1.ajax技术的背景 不可否认,ajax技术的流行得益于google的大力推广,正是由于google earth.google suggest以及gmail等对ajax技术的广泛应用,催生了ajax ...

  7. Ajax工作原理(转)

    1.ajax技术的背景 不可否认,ajax技术的流行得益于google的大力推广,正是由于google earth.google suggest以及gmail等对ajax技术的广泛应用,催生了ajax ...

  8. Ajax的原理和运行机制

    关于ajax,是最近炒得非常火的一种技术,并且时下它也是非常流行.当然,它并不是什么新技术,而是在各种已有的技术和支持机制下的一个统一.在我的项目中,偶尔也会用到ajax,用来给用户一些无刷新的体验. ...

  9. Ajax 技术原理(转)

    Ajax 技术原理 2010-01-04 原文出处:http://www.nowamagic.net/ajax/ajax_AjaxPrinciple.php 在写这篇文章之前,曾经写过一篇关于AJAX ...

  10. (转)Ajax的原理和应用

    1.ajax技术的背景 不可否认,ajax技术的流行得益于google的大力推广,正是由于google earth.google suggest以及gmail等对ajax技术的广泛应用,催生了ajax ...

随机推荐

  1. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  2. 使用struct处理二进制

    有的时候需要用python处理二进制数据,比如,存取文件.socket操作时.这时候,可以使用python的struct模块来完成. struct模块中最重要的三个函数是pack(), unpack( ...

  3. html5 canvas常用api总结(三)--图像变换API

    canvas的图像变换api,可以帮助我们更加方便的绘画出一些酷炫的效果,也可以用来制作动画.接下来将总结一下canvas的变换方法,文末有一个例子来更加深刻的了解和利用这几个api. 1.画布旋转a ...

  4. 如何优雅的使用RabbitMQ

    RabbitMQ无疑是目前最流行的消息队列之一,对各种语言环境的支持也很丰富,作为一个.NET developer有必要学习和了解这一工具.消息队列的使用场景大概有3种: 1.系统集成,分布式系统的设 ...

  5. CentOS7 重置root密码

    1- 在启动grub菜单,选择编辑选项启动 2 - 按键盘e键,来进入编辑界面 3 - 找到Linux 16的那一行,将ro改为rw init=/sysroot/bin/sh 4 - 现在按下 Con ...

  6. Asp.Net WebApi核心对象解析(上篇)

    生活需要自己慢慢去体验和思考,对于知识也是如此.匆匆忙忙的生活,让人不知道自己一天到晚都在干些什么,似乎每天都在忙,但又好似不知道自己到底在忙些什么.不过也无所谓,只要我们知道最后想要什么就行.不管怎 ...

  7. HIVE教程

    完整PDF下载:<HIVE简明教程> 前言 Hive是对于数据仓库进行管理和分析的工具.但是不要被“数据仓库”这个词所吓倒,数据仓库是很复杂的东西,但是如果你会SQL,就会发现Hive是那 ...

  8. c# 基础 object ,new操作符,类型转换

    参考页面: http://www.yuanjiaocheng.net/webapi/config-webapi.html http://www.yuanjiaocheng.net/webapi/web ...

  9. H5 canvas的 width、height 与style中宽高的区别

    Canvas 的width height属性 1.当使用width height属性时,显示正常不会被拉伸:如下 <canvas id="mycanvas" width=&q ...

  10. 张小龙宣布微信小程序1月9日发布,并回答了大家最关心的8个问题

    2016 年 12 月 28 日,张小龙在微信公开课 PRO 版的会场上,宣布了微信小程序的正式发布时间. 微信小程序将于 2017 年 1 月 9 号正式上线. 同时他解释称,小程序就像PC时代的网 ...