ajax——XMLHttpRequest
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的更多相关文章
- 【02】AJAX XMLHttpRequest对象
AJAX XMLHttpRequest对象 XMLHttpRequest 对象用于与服务器交换数据,能够在不重新加载整个网页(刷新)的情况下,对网页进行部分更新. XMLHttpRequest 对 ...
- 异步访问技术Ajax(XMLHttpRequest)
目录 AJAX XMLHttpRequest Ajax向服务器发送请求 Ajax接收服务器响应 AJAX - onreadystatechange 事件 使用 Callback 函数 一次Ajax请求 ...
- ajax+XMLHttpRequest里的FormData实现图片异步上传
发这篇博客的时候我是自己在研究这个XMLHttpRequest请求,在别人的博客上面知道XMLHttpRequest新加了一个FormData的东西,好像现在APP请求后台也有用这种方式的吧. 别的不 ...
- Ajax&XMLHttpRequest
XMLHttpRequest 简单省力的方法 将文件编码成base64通过Ajax上传 HTML5学习之FileReader接口 HTML5学习之FileReader接口 通过Ajax方式上传文件,使 ...
- 不同浏览器创建 ajax XMLHTTPRequest对象的方法及兼容性问题总结
XMLHttpRequest 对象是AJAX功能的核心,要开发AJAX程序必须从了解XMLHttpRequest 对象开始. 了解XMLHttpRequest 对象就先从创建XMLHttpReques ...
- 原生Ajax XMLHttpRequest对象
一.Ajax请求 - 现在常见的前后端分离项目中,一般都是服务器返回静态页面后浏览器加载完页面,运行script中的js代码,通过ajax向后端api发送异步请求获取数据,然后调用回调函数,将数据添加 ...
- 【转载并整理】AJAX XmlHttpRequest对象详解
一. XMLHttpRequest由来及原生介绍 XMLHttpRequest(XHR)是一个API对象,其中的方法可以用来在浏览器和服务器端传输数据.这个对象是浏览器的js环境提供的.从XHR获取数 ...
- AJAX——XMLHttpRequest对象的使用
AJAX是web2.0即动态网页的基础,而XMLHttpRequest对象又是AJAX的核心.XMLHttpRequest对象负责将用户信息以异步通信地发送到服务器端,并接收服务器响应信息和数据 一. ...
- java 设置允许ajax XMLHttpRequest 请求跨域访问
怎样才能算跨域?协议,域名,端口都必须相同,才算在同一个域. 方案1: 使用XMLHttpRequest... 异步请求不能跨域访问,除非要访问的网页响应头信息设置为允许跨域访问. 将网页设置为允许 ...
随机推荐
- noi25 最长最短单词(为什么会出现运行时错误)
noi25 最长最短单词(为什么会出现运行时错误) 一.总结 一句话总结:比如除以零,数组越界,指针越界,使用已经释放的空间,数组开得太大,超出了栈的范围,造成栈溢出 1.c++报runtime er ...
- 基于深度学习的目标检测(object detection)—— rcnn、fast-rcnn、faster-rcnn
模型和方法: 在深度学习求解目标检测问题之前的主流 detection 方法是,DPM(Deformable parts models), 度量与评价: mAP:mean Average Precis ...
- Oracle 中的Interger类型
引自 wolfAone, oracle有没有integer类型,这种类型的最大值是多少啊. Integer是Number类型的子类型: NUMBER Type You use the NUMBER d ...
- 使用vue-cil搭建项目
原文: 简书原文:https://www.jianshu.com/p/1af9b72cf86e 大纲 1.安装NodeJs 2.安装vue-cli 3.创建项目 4.启动项目 5.打包项目 6.项目实 ...
- [Angular] Alternative Themes - Learn the Host-Context Selector
To add alernative theme, we can use :host-context() selector from Angular. //au-fa-input-red-theme.c ...
- [Angular2 Form] Create custom form component using Control Value Accessor
//switch-control component import { Component } from '@angular/core'; import { ControlValueAccessor, ...
- php实现数值的整数次方
php实现数值的整数次方 一.总结 没有考虑到指数为负数的情况 二.php实现数值的整数次方 题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exp ...
- POJ 2914 Minimum Cut 最小割算法题解
最标准的最小割算法应用题目. 核心思想就是缩边:先缩小最大的边.然后缩小次大的边.依此缩小 基础算法:Prime最小生成树算法 只是本题測试的数据好像怪怪的,相同的算法时间执行会区别非常大,并且一样的 ...
- Annotation研究的一些学习资料
转自chanyinhelv原文Annotation研究的一些学习资料 下面是我最近对Annotation研究的一些学习资料,收集于此,供大家学习之用. 一.Annotation要素类介绍 在GeoDa ...
- [React Native] Animate Styles of a React Native View with Animated.timing
In this lesson we will use Animated.timing to animate the opacity and height of a View in our React ...