ajax基本介绍
AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML【Extensible Markup Language】 ),是指一种创建交互式网页应用的网页开发技术。对于传统的数据交互而言,数据都是存储在服务器端,想要请求数据或者提交数据,只能同步实现数据的传输,那么在数据提交或者是数据获取的过程中,用户必须等待信号传递、数据处理、数据打包等过程,无法实现用户在等待过程中也能进行其他操作的体验,这对于浏览器而言并不是一个友好的体验。
使用AJAX就解决了这个问题,他通过少量数据的传输,获得改变页面少量信息的数据,再通过JS控制页面的局部刷新,使得页面交互过程不必再刷新整个页面,也不用用户等待数据处理完成。由于用户并不关心数据什么时候处理完成,所以AJAX的实现是一个异步的过程。
总而言之,AJAX的优势就是在于:
- 使用Javascript向服务器提出请求并处理响应而不阻塞用户!核心对象XMLHTTPRequest。通过这个对象,您的 JavaScript 可在不重载页面的情况与Web服务器交换数据。
- AJAX 在浏览器与 Web 服务器之间使用异步数据传输(HTTP 请求),这样就可使网页从服务器请求少量的信息,而不是整个页面。
使用原生JS执行流程,主要为以下步骤:
- 创建XMLHttpRequest对象(考虑浏览器兼容的问题)
var xhr = function getXmlHttpObject() {
var objXMLHttp = null;
if (window.XMLHttpRequest) {
objXMLHttp = new XMLHttpRequest();
} else if (window.ActiveXObject) {
objXMLHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
return objXMLHttp;
}
2、使用XMLHttpRequest对象打开一个连接(指定连接方式和连接地址以及是否同步),接收三个参数,分别为请求的类型,请求的路径以及指明采用同步还是异步,异步请求为true
xhr.open("POST","URL ",true);
3、建立连接之后,需要发送数据。这时候需要对数据有一个说明,所以需要设置请求的头部(请求的类型和请求的编码格式),请求头的设置只能在open之后,send之前
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
4、发送请求,根据请求类型,采用get直接调用send()方法,数据通过url发送大服务器;采用post需要将数据作为方法的参数传递。
xhr.send(data);
5、设置回调函数,当ajax数据传递完成,并且客户端和服务端正常,那么就可以执行ajax完成后的操作。这里是一个事件监听函数,信息在客户端和服务端传递时就会触发该函数,而我们就能在响应完成后的xhr对象上获得服务端返回的数据
ajax状态码(readyState):
0 - (未初始化)还没有调用send()方法
1 - (载入)已调用send()方法,正在发送请求
2 - (载入完成)send()方法执行完成,已经接收到全部响应内容
3 - (交互)正在解析响应内容
4 - (完成)响应内容解析完成,可以在客户端调用了
xhr.onreadystatechange=function(){
//如果readyState为4,表示响应已经被完全接收。
if(xhr.readyState==4){
//如果获得的结果状态代码为200,表示服务端正常返回
if(xhr.status==200){
var txt=xhr.responseText;
document.getElementById("err").innerHTML=txt;
}
}
}
完整代码:
var xhr = getXmlHttpObject();
xhr.open("get", "./users.json", true);
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.send();
xhr.onreadystatechange = function() {
//如果readyState为4,表示响应已经被完全接收。
if (xhr.readyState == 4) {
//如果获得的结果状态代码为200,表示服务端正常返回
if (xhr.status == 200) {
var txt = xhr.responseText;
console.log(txt);
}
}
} function getXmlHttpObject() {
var objXMLHttp = null;
if (window.XMLHttpRequest) {
objXMLHttp = new XMLHttpRequest();
} else if (window.ActiveXObject) {
objXMLHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
return objXMLHttp;
}
ajax基本介绍的更多相关文章
- Ajax【介绍、入门、解决Ajax中文、跨域、缓存】
什么是Ajax Ajax(Asynchronous JavaScript and XML) 异步JavaScript和XML Ajax实际上是下面这几种技术的融合: (1)XHTML和CSS的基于标准 ...
- 关于ajax原理介绍
1.ajax技术的背景 不可否认,ajax技术的流行得益于google的大力推广,正是由于google earth.google suggest以及gmail等对ajax技术的广泛应用,催生了ajax ...
- Ajax简单介绍和使用步骤
Ajax被认为是(Asynchronous(异步) JavaScript And Xml的缩写).现在,允许浏览器与服务器通信而无须刷新当前页面的技术都被叫做Ajax. 同步是指:发送方发出数据后,等 ...
- AJAX入门介绍
在我们平时的开发过程中,经常使用到Ajax数据交互,相信有很大一部分人会使用,可能没太详细了解过Ajax的工作原理.下面我们一起看一下吧! ( 一 ) 什么是Ajax Ajax 即“Asynchron ...
- ajax详细介绍
a.什么是Ajax Asynchronous JavaScript and XML(异步JavaScript和XML) 节省用户操作,时间,提高用户体验,减少数据请求 传输获取数据 ...
- ajax的介绍
$.ajax({ 11 url: "article.asmx/GetArticleByID", 12 type: "POST", 13 datatype: &q ...
- AJax知识介绍
参考:http://www.runoob.com/ajax/ajax-asp-php.html
- AJAX简单介绍
什么是AJAX Ajax 是 AsynchronousJavaScript and XML(以及 DHTML 等)的缩写. HTML 用于建立 Web表单并确定应用程序其它部分使用的字段. ·J ...
- ajax ajax基本介绍
jquery中ajax方法参数详解 url 要求是string类型参数(默认为当前页面地址) 发送请求的地址 type 要求是string类型的参数,请求方式(post或get)默认为get.注意其他 ...
随机推荐
- Android中显示gif动态图片
在android中显示一个静态图片比如png jpg等等都很方便,但是如果要显示一个gif 动态图片就需要进行一些处理. 本文是采用自定义view 然后进行重新onDraw方法来实现 首先自定义Vie ...
- AngularJS进阶(三十)AngularJS项目开发技巧之图片预加载
AngularJS项目开发技巧之图片预加载 绪 项目(移动端采用Ionic 框架)开发完毕,测试阶段发现移动APP首页的广告图片(图片由服务器端返回相应url地址)很难加载,主要原因还是网速.如下图左 ...
- Xcode中的调试工具栏简介
如下图所示: 从左至右,第一个按钮用来隐藏调试区域. 第二个按钮向你展示断点是否被全局开启或禁用.如果它不是高亮蓝色,则没有断点会被触发. 第三个按钮暂停或继续程序的执行,你一般点击它继续运行到程序的 ...
- MySQL正则表达式初步
如果想要了解完整的MySQL手册, 请访问: MySQL 5.1参考手册 你还可以学习: MySQL学习精粹 我们知道,在SQL之中,可以用 like 这个谓词(表达式) 来进行模糊检索,并支持 %, ...
- infiniDB的论坛
http://infinidb.co/community 包括了基本的内容. 安装目录?
- C++多重继承与虚拟继承
本文只是粗浅讨论一下C++中的多重继承和虚拟继承. 多重继承中的构造函数和析构函数调用次序 我们先来看一下简单的例子: #include <iostream> using namespac ...
- Linux网络设置(第二版) --Linux网络设置
Linux网络设置 --网络配置文件与命令 个 附- 服务程序可以不使用固定端口,但是一般对外公开的WebServer不会改变端口,但是像SSH一般推荐更改,可以回避扫描 nmap [IP地址] #扫 ...
- how tomcat works 5 servlet容器 下
上一节,我们主要说的是Wrapper容器,这一节我们说Context容器. 再重申一遍,一个Context容器可以包含多个Wrapper容器; 一个Wrapper容器就表示一个独立的servlet. ...
- 网站开发进阶(十八)js获取html标签中的值
js获取html标签中的值 项目开发过程中,由于需求所迫,需要获取html标签元素中的内容,下面做一简单总结.以下所讲的示例适用于其它标签元素. 主要包括2中方法获取元素内容: 方法一:.innerT ...
- Linux - /etc/passwd和/etc/shadow文件结构
/etc/passwd文件结构 1.账号名称: 就是账号啦!用来对应 UID 的.例如 root 的 UID 对应就是 0 (第三字段): 2.口令: 早期 U ...