XMLHttpRequest对象。能够让ajax程序在不又一次载入的页面的情况下更新页面数据,页面载入完毕后从server接受发生数据。这样既减轻了server负担又回顾了响应速度,缩短了用户的等待时间,让web程序更类似于传统的桌面应用。

XMLHttpRequest对象4步用法:

1.建立XMLHttpRequest对象。

建立XMLHttpRequest对象时。要依据浏览器的不同版本号去建立,由于IE5.0和iE6.0,开发者就能够在WEB页面内部使用XMLHTTP
ActiveX组件扩展自身的功能;而从IE7版本号以上以及其它厂商的浏览器,開始创建继承XML的代理类XMLHttpRequest,所以创建上会有不同。

         var xmlhttp;//定义全局变量   
<span style="white-space:pre">	</span>//1.创建xmlhttprequest对象
if (window.XMLHttpRequest) {
//firefox等其它浏览器、ie7、8及以上版本号适用
xmlhttp = new XMLHttpRequest();
if (xmlhttp.overrideMimeType) {
xmlhttp.overrideMimeType("text/xml");
} else if (window.ActiveXObject) {
//ie5、6版本号版本号适用
var activexName = ["MSXML2.XMLHTTP.6.0", "MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0", "MSXML2.XMLHTTP.3.0","MSXML2.XMLHTTP","Miscrosoft.XMLHTTP"];
for (var i = 0; i < activexName.length; i++) {
try {
xmlhttp = new ActiveXObject(activexName[i]);
break;
} catch (e) { }
}
}
if (xmlhttp==undefined || xmlhttp==null) {
alert("当前浏览器不支持创建xmlhttprequest对象");
return;
}

2.注冊回调函数

                //2.注冊一个回调方法
xmlhttp.onreadystatechange = callback;

3.使用open方法设置和server交互的信息,并设置发送的数据。

open方法中的也有get和post的提交方式。

post的方式时。要设置它的头文件。而且须要发送时须要将參数写的send中

                //GET方式交互
//3.设置和server交互的对应參数
xmlhttp.open("GET", "HtmlPage1.ashx? username=" + userName, true);
////设置server端发送的数据。启动和server的交互
xmlhttp.send(null);
                //POST方式交互
//3.利用open,设置和server交互的对应參数
xmlhttp.open("POST", "HtmlPage1.ashx", true);
xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); //POST方式所须要添加的代码,头文件
//设置server端发送的数据。启动和server的交互。以及传递參数
xmlhttp.send("username=" + userName);

4.在回调函数中推断交互是否完毕,响应是否正确,并依据须要获取server端返回的数据,更新页面内容。

                //回调函数
function callback()
{
//5.推断和server器的交互是否完毕,server端是否正确返回了数据
if (xmlhttp.readyState == 4) {//表示server端的交互已经完毕
if (xmlhttp.status == 200) {//表示正确的返回了数据
//纯文本的方法接受方法
var message = xmlhttp.responseText;
//xml数据相应的dom对象的接受方法
//使用的前提是,server端须要设置
//记忆向div标签中加入文本内容
var div1 = document.getElementById("message");
div1.innerHTML = message;
}
}
}

XMLHttpRequest的具体属性和方法:

open() 指定server端交互的http方法(post or get)、url地址、是否异步等信息
send() 向server发出请求。假设採用异步。该方法马上返回。其内容能够是null。dom对象。输入流。字符串
setRequestjeader() 设置http的头文件,在open方法以后调用。

getallResponseHeaders() 包括http的全部对应头文件信息。
getResponseHeader() 返回http相应头文件里指定的键名header相应值。
abort() 停止当前http请求,相应的xmlhttprequest对象复位到未初始化的状态
readyState 异步操作的状态:未初始化(0),正在载入(1)。已载入(2)。交互(3)。已完毕(4)
onreadystatechange() 请求状态改变的事件触发器。

(可注冊函数)

responseText server响应的文本内容。
responseXML server响应的XML内容相应的DOM对象
status server返回的HTTP状态码。200成功。
statusText server返回状态码的文本信息

总结:

在Ajax应用程序中,XMLHttpRequest对象负责将用户信息以异步通信地发送到server端。并接收server响应信息和数据。

ajax——XMLHttpRequest的更多相关文章

  1. 【02】AJAX XMLHttpRequest对象

    AJAX XMLHttpRequest对象   XMLHttpRequest 对象用于与服务器交换数据,能够在不重新加载整个网页(刷新)的情况下,对网页进行部分更新. XMLHttpRequest 对 ...

  2. 异步访问技术Ajax(XMLHttpRequest)

    目录 AJAX XMLHttpRequest Ajax向服务器发送请求 Ajax接收服务器响应 AJAX - onreadystatechange 事件 使用 Callback 函数 一次Ajax请求 ...

  3. ajax+XMLHttpRequest里的FormData实现图片异步上传

    发这篇博客的时候我是自己在研究这个XMLHttpRequest请求,在别人的博客上面知道XMLHttpRequest新加了一个FormData的东西,好像现在APP请求后台也有用这种方式的吧. 别的不 ...

  4. Ajax&XMLHttpRequest

    XMLHttpRequest 简单省力的方法 将文件编码成base64通过Ajax上传 HTML5学习之FileReader接口 HTML5学习之FileReader接口 通过Ajax方式上传文件,使 ...

  5. 不同浏览器创建 ajax XMLHTTPRequest对象的方法及兼容性问题总结

    XMLHttpRequest 对象是AJAX功能的核心,要开发AJAX程序必须从了解XMLHttpRequest 对象开始. 了解XMLHttpRequest 对象就先从创建XMLHttpReques ...

  6. 原生Ajax XMLHttpRequest对象

    一.Ajax请求 - 现在常见的前后端分离项目中,一般都是服务器返回静态页面后浏览器加载完页面,运行script中的js代码,通过ajax向后端api发送异步请求获取数据,然后调用回调函数,将数据添加 ...

  7. 【转载并整理】AJAX XmlHttpRequest对象详解

    一. XMLHttpRequest由来及原生介绍 XMLHttpRequest(XHR)是一个API对象,其中的方法可以用来在浏览器和服务器端传输数据.这个对象是浏览器的js环境提供的.从XHR获取数 ...

  8. AJAX——XMLHttpRequest对象的使用

    AJAX是web2.0即动态网页的基础,而XMLHttpRequest对象又是AJAX的核心.XMLHttpRequest对象负责将用户信息以异步通信地发送到服务器端,并接收服务器响应信息和数据 一. ...

  9. java 设置允许ajax XMLHttpRequest 请求跨域访问

    怎样才能算跨域?协议,域名,端口都必须相同,才算在同一个域. 方案1: 使用XMLHttpRequest...  异步请求不能跨域访问,除非要访问的网页响应头信息设置为允许跨域访问. 将网页设置为允许 ...

随机推荐

  1. QQ群功能设计与心理学

    刚刚在一个Java技术交流群,发了个 "博客投票"的广告. 群主两眼一黑,瞬间就把我给干掉了. 看到QQ给出的系统消息,发现QQ群的一个功能做得很不错. 大家注意到,右边有个&qu ...

  2. uva 1463 - Largest Empty Circle on a Segment(二分+三分+几何)

    题目链接:uva 1463 - Largest Empty Circle on a Segment 二分半径,对于每一个半径,用三分求出线段到线段的最短距离,依据最短距离能够确定当前R下每条线段在[0 ...

  3. h5做app和原生app有什么区别?

    h5做app和原生app有什么区别? 一.总结 一句话总结: 二.h5做app和原生app有什么区别? 普通的HTML5技术与原生技术相比,有跨平台.动态.开放.直达二级内容页面等特点,但却在性能.工 ...

  4. less相关知识点

    less是一门css预处理语言,文件后缀名为.less,能减少css文件编写的代码量 官网 http://lesscss.cn/#using-less 安装 使用npm install -g less ...

  5. Iceberg使用

    Iceberg是Mac下比較好用的pkg生成工具. 在files中选择你想要存放(自己文件的目录),生成pkg后目录就会存储在设置的那个目录下. 点击scripts选择pkg安装各个阶段所要运行脚本路 ...

  6. Android javaMail使用imap协议接收邮件

    在这里说明一下,pop3和imap协议都是接收邮件的,但是他们还是有很多不同的. IMAP和POP有什么区别? POP允许电子邮件客户端下载服务器上的邮件,但是您在电子邮件客户端的操作(如:移动邮件. ...

  7. Redis学习笔记--Hash(五)

    Redis的数据是通过key-value的方式存储的,对于value的数据类型有字符串.Hash.list.set.sortedSet在redis命令语句中,语句是忽略大小写的,但是key是不可以忽略 ...

  8. apache与IIS共用80端口冲突解决方法

    如果同一台电脑安装了apache和iis,会提示80端口冲突,如何解决apache与iis 80端口冲突的问题呢,并且同时使用apache和iis 将apache设为使用80端口,IIS使用其它端口, ...

  9. 手把手教你----MyEclipse中 配置 Tomcat

    电脑上配置Tomcatserver 安装Tomcat并配置环境变量 測试是否配置成功 MyEclipse中配置Tomcat 想要开发Java Web的程序.首先在MyEclipse中必须配置Tomca ...

  10. Codeforces Round #Pi (Div. 2) B Berland National Library

    B. Berland National Library time limit per test1 second memory limit per test256 megabytes inputstan ...