ajax是什么呢?说白了就是一个请求,一个读取服务器资源以及提交资源到服务器的中间处理机制,那它具体是怎样工作的,又有怎样的原理呢?

var ajax=function(url,fnSucceed,fnFail){
//第一步:初始化http协议,即实例化一个XMLHttpRequest方法。
//这里还需要做判断,因为微软的老版本IE(<IE7)与众不同的是,它的ajax是通过一个ActiveXObject控件实现的,
//并不是其他浏览器的XMLHttpRequest,这是一种兼容写法。现在其实可以就用XMLHttpRequest来,毕竟连阿里都宣布
//不支持IE8以下的了。
if(window.XMLHttpRequest){
var oAjax=new XMLHttpRequest();
}
else{
var oAjax=new ActiveXObject("Microsoft.XMLHTTP");
}
//第二步:设置发起请求的内容,方式,要访问哪里?哪个url?是要读还是写?(即get 还是 post)是同步还是异步?
oAjax.open('GET',url,true);
//true是异步,要同步就是false,
//get一般用于读取服务器数据或资源文件。
//post一般则是用于用户上传数据时回传至服务器,但这两个实际上都是可读可写,只不过是数据传送的方式不同,
// 之所以人们一般会这样用主要体现在下面这些方面:
// 1、get是通过地址栏传输(可以仔细看我们浏览器的上方地址栏,里面的信息会包括一些比较机密的信息,比如:
// 当用户注册后的信息,如果此时用get进行提交会发生什么呢?你看最上方的地址栏,里面显示的恰恰好是你的账户跟
// 密码,这就很恐怖了,也非常不安全),而post是通过报文传输,数据不会在地址栏显示,会帮你把提交的数据隐藏,
// 相对来说比较安全,get中的url有长度限制,最大长度是2k,也就是2048个字符,而post则无限制,
// 而说到这你可能就会说了,既然post方式这么多优点,那为啥不都用post就可以了?
// 你又错了,是的,post本身也是有限制的,比如:
// 你在浏览网页的时候点快了,要后退刷新什么的,用get呢因为他本质上是获取服务上的资源,而你后退实际上并没有
//要获取服务器上资源的意思(浏览器读得懂),而用post呢?post本质是什么呢?是向服务器提交资源或数据,所以用
//post的时候,你后退了,浏览器还以为你又要提交什么东西,那它就会把数据再重新提交给服务器,造成重复提交数据
//说到本质上的东西,你现在知道为什么get有2k的限制了吧?get就是获取,由于对于一个服务器上的资源的获取实际上
// 是获取资源的url或者再本质点就是一个标识符,资源标识(url不代表就是资源的实际物理地址),这个一般不会太长,
//也没必要太长,你见过地址栏的东西有一大串一大串的吗?没有吧?而post呢?还是回归本质,英文的意思是什么呢?
//帖子,投递,说白了就是上传或提交,我想当初ajax底层XMLHttpRequest他们的作者也肯定希望我们用post就是用来投递,
//用来提交资源的,而get(得到)就是用来获取资源的,它们既然这样想,在设计程序的时候肯定也是这样设计的了,关于
// 这两个不必要研究太深入,只需要牢记语义化,get 读取资源,post 提交资源,这样你就可以搞定9成9的ajax请求了,
//而这,够了!我们不是科学家,钻牛角尖的东西,钻到一定程度就够了,当然如果你有时间推荐深入去研究,好事。 //第三步:发送请求。
oAjax.send(); //第四步:处理请求
/**这第4步有个大坑,什么坑呢?既然是响应终端客户操作的交互请求,那客户什么时候操作呢?我们不知道,服务器也
* 不会知道。那怎么办呢?如果你学过java,有四个字你一定不陌生,说到这你可能想到了,没错,就是事件监听
* 但我们这个ajax呢?它不是这样的,它采用的是js里一直被其他程序语言开发者诟病的回调机制,具体是怎样的呢?
*
* 我们刚刚开头实例化了一个XMLHttpRequest,它提供了三个属性:
* 1、onreadystatechange:拆开看 on readystate change,当readystate这个属性变化的时候,调用这个函数
* 是的,你没翻译错,它就是一个函数,一个回调函数,一个存储了我们预先设置好当用户
* 发起请求后我们要做(或者说服务器要做)的响应操作,一句话,存函数的
*
* 2、readyState:刚刚你是不是在纳闷,我为啥要那样翻译呢?而不是on ready state change呢?看到这个你恍然大悟
* 了吧?嘿嘿,其实正确的翻译还真是第2次翻译的这个,就是当预备的状态改变时,只不过预备的状态
* 我就当成这个了,这样你印象会比较深,没错,语义化,readyState这个就是XMLHttpRequest的状态
* 这个readyState的状态是预先约定俗成好的,类似于协议这样,可以当成一个switch开关,它有几个case,没错
* 就是这么任性,这么认为没问题的,具体是哪几个case呢?
* 0:请求未初始化
* 1:服务器连接已建立
* 2:请求已接收
* 3:请求处理中
* 4:请求已完成,且响应已就绪。(这个用得比较多,毕竟服务器内部的我们并不关心,我们只关心结果)
*
* 3、status:这个也是一个状态,它的可填属性呢,有一大堆:0**(未初始化),1**(请求收到,继续处理),2**,
* 3**,4**,5**,太多了这里就不列举了,有个statusText状态表可自行去查,不过想说的是一般情况下,
* 服务器对数据的处理,响应我们没必要去管它到底是执行到哪一步了?(数据接收不到调试的话除外)
* 我们只需要判断它是否接收完请求,并是否能成功做出响应就可以了,所以呢,我们记住几个常用的就可
* 以了,大脑容量有限,我们应该记一些最精华的部分,而不是越多越好,当然必须先明白原理才可以。
* 这里呢,我列几个吧:
* 200:"OK",最常用,成功的意思 (开发者可能比较多用这个)
* 401:请求授权失败
* 404:未找到页面
* 500:服务器产生内部错误
* 12029:网络不通
*
* 啰嗦了这么多,没实操怎么行呢?
* */
oAjax.onreadystatechange=function(){
if(oAjax.readyState==4){
if(oAjax.status==200){
fnSucceed(oAjax.responseText);//响应成功回调的函数,这里只是简简单单的返回了一串数据,
//可以在里面或外部的函数里继续写其他响应操作
}
else{
if(fnFail){
fnFail(oAjax.status);
}
}
}
};//我们这里存了一个函数了
};
下面贴一个自己写的代码(其实上面都有了,只不过比较杂)
/**
* Created by Administrator on 2018/5/1 0001.
*/
var dc_ajax_g=function(url,fnSucceed,fnFail) {
//if (window.XMLHttpRequest) {
var oAjax = new XMLHttpRequest();
//}
//else {
// var oAjax = new ActiveXObject("Microsoft.XMLHTTP");
//};
oAjax.open('GET',url,true);
oAjax.send();
oAjax.onreadystatechange=function(){
if(oAjax.readyState==4){
if(oAjax.status==200){
fnSucceed(oAjax.responseText);//响应成功回调的函数,这里只是简简单单的返回了一串数据,
//可以在里面或外部的函数里继续写其他响应操作
}
else{
if(fnFail){
fnFail(oAjax.status);
}
}
}
};
};

关于ajax原理阐述的更多相关文章

  1. AJAX原理总结

    AJAX全称 Asynchronous JavaScript and XML(异步的JavaScript 和XML) 同步和异步 异步传输是面向字符的传输,单位是字符 同步传输是面向比特,单位是帧,传 ...

  2. 什么是ajax,ajax原理是什么 ,优缺点是什么

    AJAX工作原理及其优缺点   1.什么是AJAX?AJAX全称为“Asynchronous JavaScript and XML”(异步JavaScript和XML),是一种创建交互式网页应用的网页 ...

  3. ajax原理图解

    Ajax 原理图解 摘自: http://www.nowamagic.net/ajax/ajax_PicForAjaxPrinciple.php Ajax其实已经使用很久了,但一直也没有时间正经的找本 ...

  4. 浅析ajax原理与用法

    1 ajax原理 Ajax(Asynchronous JavaScript and XML (异步的JavaScript和XML)),是一种快速创建 动态网页的技术,目的是显示动态局部刷新.通过XML ...

  5. Ajax原理一篇就够了

    Ajax原理一篇就够了 一.什么是Ajax Ajax(Asynchronous JavaScript and XML的缩写)是一种异步请求数据的web开发技术,对于改善用户的体验和页面性能很有帮助.简 ...

  6. 封装ajax原理

    封装ajax原理 首先处理 用户如果不传某些参数,设置默认值 type默认get 默认url为当前页 默认async方式请求 data数据默认为{} 处理用户传进来的参数对象 遍历,拼接成key=va ...

  7. 简述Ajax原理及实现步骤

    简述Ajax原理及实现步骤 1.Ajax简介 概念 Ajax 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML). 现在允许浏览器与务器通信 ...

  8. 大话AJAX原理

    大话AJAX原理 一.什么是Ajax Ajax(Asynchronous JavaScript and XML的缩写)是一种异步请求数据的web开发技术,对于改善用户的体验和页面性能很有帮助.简单地说 ...

  9. Ajax -- 原理及简单示例

    1. 什么是Ajax •Ajax被认为是(AsynchronousJavaScript and XML的缩写).现在,允许浏览器与服务器通信而无须刷新当前页面的技术都被叫做Ajax. 2. Ajax ...

随机推荐

  1. 在mysql数据库中创建oracle scott用户的四个表及插入初始化数据

    在mysql数据库中创建oracle scott用户的四个表及插入初始化数据 /* 功能:创建 scott 数据库中的 dept 表 */ create table dept( deptno int ...

  2. iOS开发支付集成之支付宝支付

    项目中要用到支付功能,需要支付宝,微信,银联三大支付,所以打算总结一下,写两篇文章,方便以后的查阅, 大家在做的时候也能稍微参考下,用到的地方避免再次被坑.这是第二篇支付宝集成,第一篇银联支付在这里. ...

  3. 《java入门第一季》之Arrays类

    前面介绍了排序问题(见博客http://blog.csdn.net/qq_32059827/article/details/51362390):二分查找问题(见博客http://blog.csdn.n ...

  4. Cocos2D v2.0至v3.x简洁转换指南(四)

    实现通用的update方法 在Cocos2d 2.x你需要2个步骤去实现在每帧调用update方法: // 1) schedule update [self scheduleUpdate]; ... ...

  5. android数据保存之greendao

    有时我们的数据属于保存到数据库,对于Android应用和IOS应用,我们一般都会使用SQLite这个嵌入式的数据库作为我们保存数据的工具.由于我们直接操作数据库比较麻烦,而且管理起来也非常的麻烦,以前 ...

  6. 数据结构是哈希表(hashTable)

    哈希表也称为散列表,是根据关键字值(key value)而直接进行访问的数据结构.也就是说,它通过把关键字值映射到一个位置来访问记录,以加快查找的速度.这个映射函数称为哈希函数(也称为散列函数),映射 ...

  7. LeetCode之“动态规划”:Scramble String

    题目链接 题目要求: Given a string s1, we may represent it as a binary tree by partitioning it to two non-emp ...

  8. Gradle 1.12用户指南翻译——第三十五章. Sonar 插件

    本文由CSDN博客万一博主翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

  9. 通信录列表+复杂Adapter分析

    概述 最近写论文之余玩起了github,发现有个citypicker挺不错的,高仿了美团城市选择和定位的一些功能 地址链接 效果图如下: 自己手动写了一遍优化了一些内容,学到了一些姿势,下面对其中一些 ...

  10. 解决 RabbitMQ 集群 Channel shutdown: connection error 错误(HAProxy 负载均衡)

    相关文章:搭建 RabbitMQ Server 高可用集群 具体错误信息: 2018-05-04 11:21:48.116 ERROR 60848 --- [.168.0.202:8001] o.s. ...