刚开始以为Ajax是一种新的语言,接触之后才知道,ajax是用于服务器交换数据并更新部分网页的Web应用程序的技术。

第一次看到Ajax请求代码时,感觉一脸萌逼,这些代码竟然把后台数据请求过来了,神奇啊。但是写着写着第二天再写的时候发现,代码一堆,根本没记住。

  没想到好办法,老办法,抄了十来遍,其实也就是钱三遍在抄,后边直接默写出来了。这才捋顺了思路。整理了一下想法,现在把这些想法分享一下。先把代码献上,虽然很俗套。

/**********请求流程************/
1、创建请求对象
var xhr;
if(window.XMLHttpRequest){
xhr = new XMLHttpRequest();
}else if(window.ActiveXObject){
var versionArr = ["Msxml2.XMLHTTP","Microsoft.XMLHTTP"];
for(var tempVersion of versionArr){
xhr = new ActiveXObject[tempVersion];
if(xhr){
break
}
}
}else{
throw new Error("您的浏览器版本过低")
}
// 2建立连接
xhr.open("GET","url")
// 3发送请求
xhr.send(null)
// 4接收响应
xhr.onreadystatechange = function(){
if(xhr.readyState == 4&& xhr.status ==200){
var rootObj = JSON.parse(xhr.responseText)
……………………
}
}

  来,刚看完代码,这里先抛开代码。就事论代码,先从这件事开始,当你想要请求到后台数据,首先你能想到要去做什么?别说创建请求实例,一步一步按正常=逻辑倒着来。这时你应该想到肯定要先去发送请求了。那么问题来了,从哪里发送请求呢?这时候就要去想办法找这个能发送请求的东西了,然而并没有。这时候就要拿出曾经练得的一首好本领——造对象。没有请求的实例,就要先造出来一个请求实例,这就是第一步,当然了,有了他就可以往下进行了,然而发送请求也并不是随便就让发的,就像打电话,首先你得去开启电话,才可以去拨号聊天,这就是第二步,去打开一个连接,然后再进行点击拨号,发送出去你按下的号码,这就是第三部,发送请求,接下来就要处理收到的回复了。

  下面再一步一步简单解析一下

创建XMLHttpRequest请求对象,Ajax编程是通过这个对象来进行的。
由于各大厂商浏览器对XMLHttpRequest对象支持不同,尤其是IE...这里需要对不同浏览器版本进行兼容考虑。
现在大部分主流浏览器都能够支持XMLHttpRequest对象
直接使用 new XMLHttpRequest()作为请求对象;
下面是经典的IE6支持类型 new ActiveXObject("Msxml2.XMLHTTP");
最后是IE6以下支持类型new ActiveXObject("Microsoft.XMLHTTP");

当然了也有这些根本都不支持的顽固份子。。。。直接抛出错误给他们咯

然后就是打开链接 open(method,url,flag) 参数method:GET 或者POST 参数url:请求服务器的路径 参数flag 是否异步请求,现在一般都是异步啦,不设置的话会默认异步。

接下来是发送请求send() ,这里要根据请求方式不同采取发送不同的请求,如果是GET请求,send方法内的参数写一个null就行。但如果是post类型的请求,请求带有参数的haunted。这个参数要写到send方法内发送出去,另外还要设置请求头 xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded")请求头根据实际请求不同设置的类型页不一样,这里只写一个简单示例。

  最后一步就是接受服务器响应 可以通过控制台或者警告框测试,会有四次输出信息,因此便有了几种不同的对象状态码:

0:未初始化完成,这时只是创建了XMLHttpRequest对象,未调用open方法
1:初始化已完成,请求开始,开始调用open方法,未调用send方法
2:请求发送,就是说已经调用了send方法
3:开始接收服务器的响应。
4:读取接收服务器响应后返回的数据。(响应结束)

onreadystatechange事件会在234时被处罚。我们使用的时候一般只是关心第四部,到了第四部,才开始进行数据接收处理,当然了,进行到第四部也不一定意味着就大功告成了,还要看一下服务器响应状态;一般状态码返回值 200 404 500,

200是正常响应,还有令人头疼的的404,找不到要访问的网页,最令人崩溃的就是500了,服务器崩了。。。

这里我们可以利用请求对象的status属性查看服务器状态码;当进行到第四步且服务器状态码是200时,就是我们获取到数据开始请求之时。

第一次发文章,不熟悉套路 ,有问题的话我上线会及时回复的。

Ajax服务请求原理 简单总结的更多相关文章

  1. AJAX异步请求原理和过程

    AJAX 指异步 JavaScript 及 XML(Asynchronous JavaScript And XML),它不是一种新的编程语言,而是一种使用现有标准的新方法. AJAX 基于 JavaS ...

  2. Ajax - 发送请求原理

    1,什么是ajax? Asynchronous JavaScript and XML(当然现在xml已经由json代替): 主要是用于前后台的交互(表单提交已经被废弃): 使用场景:前台获取数据.表单 ...

  3. Ajax异步请求原理的分析

    我们知道,在同步请求模型中,浏览器是直接向服务器发送请求,并直接接收.处理服务器响应的数据的.这就导致了浏览器发送完一个请求后,就只能干等着服务器那边处理请求,响应请求,在这期间其它事情都做不了.这就 ...

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

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

  5. ajax请求原理

    首先分析使用ajax时候有那些不确定的因素 请求:1 请求的方式不确定 2 请求的地址不确定 3 请求是否异步不确定 4 发送的数据不确定 响应:5 返回的数据不确定 6 响应成功之后 需要处理的业务 ...

  6. SpringMVC中使用Ajax POST请求以json格式传递参数服务端通过request.getParameter("name")无法获取参数值问题分析

    SpringMVC中使用Ajax POST请求以json格式传递参数服务端通过request.getParameter("name")无法获取参数值问题分析 一:问题demo展示 ...

  7. Ajax与ashx异步请求的简单案例

    Ajax与ashx异步请求的简单案例: 前台页面(aspx): <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//E ...

  8. VueJS搭建简单后台管理系统框架 (二) 模拟Ajax数据请求

    开发过程中,免不了需要前台与后台的交互,大部分的交互都是通过Ajax请求来完成,在服务端未完成开发时,前端需要有一个可以模拟Ajax请求的服务器. 在NodeJs环境下,通过配置express可访问的 ...

  9. asp.net——Ajax与ashx异步请求的简单案例

    Ajax与ashx异步请求的简单案例: 前台页面(aspx): <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//E ...

随机推荐

  1. 宁波uber优歩司机注册教程 UBER宁波司机注册指南!

      自2012年Uber开始向全球进军以来,目前已进入全球56个国家和地区的市场,在全球超过270个城市提供服务, 而Uber公司的估值已高达412亿美元. [目前开通Uber优步叫车服务的中国城市] ...

  2. redhat6.5修改yum为163源

    把需要的安装包和配置文件打包,将命令整合到sh文件中,下载后解压运行yun_config.sh 即可 下载链接

  3. 使用Github Pages建独立博客

    http://beiyuu.com/github-pages/ Github很好的将代码和社区联系在了一起,于是发生了很多有趣的事情,世界也因为他美好了一点点.Github作为现在最流行的代码仓库,已 ...

  4. Rails学习笔记二

    rails框架: MVC模型:模型.视图.控制器 来自网站的请求先是被传递到路由,判断请求找出控制器中的方法,处理请求,控制器中的方法也被称作行为 行为可以与模型交互,访问数据库,并为视图准备信息 由 ...

  5. Maven基础知识(转)

    文章摘自http://www.cnblogs.com/xing901022/p/4170248.html 谢谢楼主的总结,界面设计的很好看! 一.什么是Maven Maven是一个用于项目构建的工具, ...

  6. amazon oa2 - insert a value into a cycled linked list

    遍历,一共有三种情况, 1. pre <= x <= current 2. 遍历到了head时,x>tail 或者 x<=head (不会等于tail) 3. 遍历回aNode ...

  7. 解决JS中各浏览器Date格式不兼容的问题

    IE,Chrome和FireFox等浏览器都支持的一种日期格式是:2015/11/30 19:29:23. 所以,可以这样写: var timeStr = new Date("2015/11 ...

  8. struts2 配置拦截器

    第一步:继承MethodFilterInterceptor写自己的自定义拦截器 import org.apache.struts2.ServletActionContext; import com.o ...

  9. 【JS】HTMLprop与attr的区别

    与prop一样attr也可以用来获取与设置元素的属性.区别在于,对于自定义属性和选中属性的处理.选中属性指的是 checked,selected 这2种属性1. 对于自定义属性 attr能够获取,pr ...

  10. 一个App Widget实例第一次创建时被调用

    事实上已经有很多的所谓的路由框架做到这一点,我也没有去研究别的,加上一直对backbone这个框架的评价不错,所以就琢磨着怎么用它实现我所需要的SPA的url管理了. 比如,你可能会说"如果 ...