Ajax_02之XHR发起异步请求
1、Ajax:
AJAX:Asynchronous Javascript And Xml,异步的JS和XML;
同步请求:地址栏输入URL、链接跳转、表单提交……
异步请求:使用Ajax发起,底层使用XMLHttpRequest对象;
2、XHR的创建:
var xhr=null;
if(window.XMLHttpRequest){xhr=new XMLHttpRequest();//新IE及其它}
else{xhr=new ActiveXObject('Microsoft.XMLHTTP');//老IE}
3、XMLHttpRequest对象的常用成员:
①成员属性:
readyState:int,初始值0;
0——UNSEND——请求消息未发送;1——OPENED——XHR已打开到服务器的链接;2——HEADERS_RECEIVED——XHR已经接收到响应消息起始行和头部;3——LOADING——XHR正在加载响应消息主体;4——DONE——XHR已经完成响应消息;
responseText:初始值"",readyState值为3时开始有响应消息主体文本;
responseXML:初始值null,readyState值为3时有响应消息主题内容——XML DOM树对象;
status:初始值0,保存响应状态码,readyState值为2时开始有值;
statusText:初始值"",保存响应消息原因短句,readyState值为2开始有值;
②成员事件:
onreadystatechange:每次readyState值发生改变就触发;
③成员方法:
open(method,url):打开到服务器的连接;
send():发送请求消息;
setRequestHeader(name,value):设置请求消息头部;
getAllResponseHeaders():获取所有的响应消息头部;
getResponseHeader(name):获取某个响应消息头部;
4、XHR对象发起异步请求步骤:
①创建XHR对象:
var xhr=new XMLHttpReponse();
②监听XHR就绪状态改变事件:
xhr.onreadystatechange=function(){}
③连接到服务器:
xhr.open(method,url,isAsync);
④发起请求消息:
xhr.send(data);
5、XHR发起异步的HTTP GET请求:
①创建XHR对象:
var xhr=new XMLHttpResponse();
②监听XHR就绪状态改变事件
xhr.onreadystatechange=function(){
if(xhr.readystate===4){
if(xhr.status===200){doResponse(xhr);}
else{alert("响应完成,但有问题");}
}
}
③连接到服务器
xhr.open('GET','x.php?k=v&k=v',true);
④发起请求消息
xhr.send(null);
6、XHR发起异步HTTP POST请求:
①创建XHR对象:
var xhr=new XMLHttpResponse();
②监听XHR就绪状态改变事件
xhr.onreadystatechange=function(){
if(xhr.readyState===4){
if(xhr.status===200){doResponse(xhr);}
else{alert("响应完成,但有问题");}
}
}
③连接到服务器
xhr.open('POST','x.php',true);
④修改请求消息头部
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
⑤发起请求消息
xhr.send('k=v&k=v');
Ajax_02之XHR发起异步请求的更多相关文章
- 设计一个方法injectBeforeAsyncSend,能够实现如下功能:在发起异步请求之前打印出请求的类型、URL、method、body、timestamp 等信息。
异步请求逻辑注入 工作中我们需要对异步请求的请求信息打印日志,但是又不能耦合在业务代码中打印.请设计一个方法injectBeforeAsyncSend,能够实现如下功能:在发起异步请求之前打印出请求的 ...
- 异步请求Ajax
AJAX:Asynchronous JS And XML,包括HTML.CSS.JS.DOM.XML.JSON等,客户端技术范畴.主要目标:发起异步请求/响应,实现页面内容的局部刷新,提高浏览体验:实 ...
- iOS NSURLConnection POST异步请求封装,支持转码GBK,HTTPS等
.h文件 #import <Foundation/Foundation.h> //成功的回调 typedef void(^successBlock)(id responseObj); // ...
- 如何在异步请求时设置RequestHeader
一.为何要用到setRequestHeader 通常在HTTP协议里,客户端像服务器取得某个网页的时候,必须发送一个HTTP协议的头文件,告诉服务器客户端要下载什么信息以及相关的参数.而 XMLHTT ...
- ajax----发送异步请求的步骤
1)获取(创建)Ajax对象:获取XMLHttpRequest对象2)创建请求:调用xhr的open方法3)在发送请求之前需要设置回调函数:绑定指定xhr的onreadystatechange事件4) ...
- 使用AJAX技术发送异步请求,HTTP服务端推送
使用AJAX技术发送异步请求 什么是AJAX AJAX指一步Javascript和XML(Asynchronous JavaScript And XML),它是一些列技术的组合,简单来说AJAX基于X ...
- .Net WebRequest异步请求与WebClient异步请求
很多情况下一般会使用同步方式发出请求,直到响应后再做后续的逻辑处理等,但有时候后续的逻辑处理不依赖于请求的结果或者是可以挂起等到响应后再处理,又或者是为了解决UI“假死”的现象,这时可以使用异步请求 ...
- 【SQL】在数据库中发起http请求的小改进
市面上常见的是用MSXML2.ServerXMLHTTP这个类,但这个类在发起异步请求时并不可靠,就是当send后并不一定会发出这个请求.这里推荐改用Microsoft.XMLHTTP,如果只是简单的 ...
- JavaScript 之 异步请求
一. 1.异步(async) 异步,它的孪生兄弟--同步(Synchronous),"同步模式"就是上一段的模式,后一个任务等待前一个任务结束,然后再执行,程序的执行顺序与任务的排 ...
随机推荐
- 一、PID控制原理
在模拟控制系统中,控制器最常用的控制规律是PID控制.模拟PID控制系统原理框图如下图.系统由模拟PID控制器和被控对象组成. PID控制器是一种线性控制器,它根据给定值Yd(t)与实际输出值Y(t) ...
- Fancybox丰富的弹出层效果
Fancybox是一款优秀的jquery插件,它能够展示丰富的弹出层效果.前面我们有文章介绍了facybox弹出层效果,相比facybox,fancybox显得功能更为齐全,它除了可以加载DIV,图片 ...
- 【BZOJ1415】 [Noi2005]聪聪和可可 概率与期望
其实题不难,不知提交了几次...不能代码MD...注意一些基本问题...SB概率题 #include <iostream> #include <cstdio> #include ...
- App Framework $.ui.loadContent 参数解释
在使用 app Framework 的 $.ui.loadContent(target,newTab,goBack,transition);时 对 newTab goback两个参数一直不得其解.通过 ...
- servlet中文乱码问题
通过response对象向页面输出内容时遇到的乱码问题可分为两种情况 1.字节流 字节流输出时可以通过设置响应头"Content-Type"的值为"text/html;c ...
- bootstrap之google fonts
bootstrap之google fonts 在学习一个bootstrap时,看到了一行引用代码:@import url(http://fonts.googleapis.com/css?family= ...
- bootstrap之移动支持
为了让 Bootstrap 开发的网站对移动设备友好,确保适当的绘制和触屏缩放,需要在网页的 head 之中添加 viewport meta 标签,如下所示: <meta name=" ...
- NFSv4的引用,迁移和备份(用户手册 v0.2)
RFC3530 定义了NFS文件系统迁移和引用的管理机制.文件系统定位功能通过fs_location属性向客户端提供文件系统的位置信息.fs_location属 性是一个包含有位置信息的列表,位置信息 ...
- js,css控制网页内容不让选中和复制
---恢复内容开始--- JS, CSS控制网页内容不让选择和复制 CSS 控制: <style> body{ -moz-user-select:none;//针对火狐浏览器,谷歌则-we ...
- (学)解决诡异的 Exception type: SocketException 127.0.0.1:80
许久不发博了,老杨听完故事让我持续写一下“十万个为什么” 一.背景: 昨天我们亲密的战友HH刘老板亲临现场,指出我们协用的一个项目,客户方面反馈手持终端系统不定期“卡死”,要我们安排人飞到广州驻场解 ...