Ajax原理一篇就够了

简介: Ajax(Asynchronous JavaScript and XML的缩写)是一种异步请求数据的web开发技术,对于改善用户的体验和页面性能很有帮助。简单地说,在不需要重新刷新页面的情况下,Ajax 通过异步请求加载后台数据,并在网页上呈现出来。

891d56a36bdf703636e3b4e52d1097c8313e3536

一、什么是Ajax

Ajax(Asynchronous JavaScript and XML的缩写)是一种异步请求数据的web开发技术,对于改善用户的体验和页面性能很有帮助。简单地说,在不需要重新刷新页面的情况下,Ajax 通过异步请求加载后台数据,并在网页上呈现出来。常见运用场景有表单验证是否登入成功、百度搜索下拉框提示和快递单号查询等等。 Ajax目的:提高用户体验,较少网络数据的传输量

二、Ajax原理是什么

在解释Ajax原理之前,我们不妨先举个“领导想找小李汇报一下工作”例子,领导想找小李问点事,就委托秘书去叫小李,自己就接着做其他事情,直到秘书告诉他小李已经到了,最后小李跟领导汇报工作。


987d8e71c83131a7b3f5411b06f111c535bc0724
Ajax请求数据流程与“领导想找小李汇报一下工作”类似。其中最核心的依赖是浏览器提供的XMLHttpRequest对象,它扮演的角色相当于秘书,使得浏览器可以发出HTTP请求与接收HTTP响应。浏览器接着做其他事情,等收到XHR返回来的数据再渲染页面。理解了Ajax的工作原理后,接下来我们探讨下如何使用Ajax。
09d5527ba0ac4e298c258fd7156d27dc866f7b1c

三、Ajax的使用

1.创建Ajax核心对象XMLHttpRequest(记得考虑兼容性)


1. var xhr=null;  
	2. if (window.XMLHttpRequest)  
	3.   {// 兼容 IE7+, Firefox, Chrome, Opera, Safari  
	4.   xhr=new XMLHttpRequest();  
	5.   } else{// 兼容 IE6, IE5 
	6.     xhr=new ActiveXObject("Microsoft.XMLHTTP");  
	7.   } 

2.向服务器发送请求


  1. xhr.open(method,url,async);  
    2. send(string);//post请求时才使用字符串参数,否则不用带参数。

method:请求的类型;GET 或 POST

url:文件在服务器上的位置

async:true(异步)或 false(同步) 注意:post请求一定要设置请求头的格式内容


xhr.open("POST","test.html",true);  
xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded");  
xhr.send("fname=Henry&lname=Ford");  //post请求参数放在send里面,即请求体

3.服务器响应处理(区分同步跟异步两种情况)

responseText 获得字符串形式的响应数据。

responseXML 获得XML 形式的响应数据。

①同步处理


1. xhr.open("GET","info.txt",false);  
	2. xhr.send();  
	3. document.getElementById("myDiv").innerHTML=xhr.responseText; //获取数据直接显示在页面上

②异步处理

相对来说比较复杂,要在请求状态改变事件中处理。


1. xhr.onreadystatechange=function()  { 
	2.    if (xhr.readyState==4 &&xhr.status==200)  { 
	3.       document.getElementById("myDiv").innerHTML=xhr.responseText;  
	4.      }
	5.    } 

readyState

0-(未初始化)还没有调用send()方法

1-(载入)已调用send()方法,正在发送请求

2-(载入完成)send()方法执行完成,已经接收到全部响应内容

3-(交互)正在解析响应内容

4-(完成)响应内容解析完成,可以在客户端调用了

status

73c76458dda76efbc942b4e2e4865d9a160cb3eb

③GET和POST请求数据区别

请求数据时的区别,详情见下面两张图:

5edaec7c8cf656a8f7934cd67467a4843c5fc5fe

3a443631aae7c31d5005e364b69a4ea3d4c8b5e9

总而言之:

  • GET请求的差数直接拼接在url上面
  • POST请求的参数就不是放在url了,而是放在send里面,即请求体

四、结束语

其实通过 XMLHttpRequest或者封装后的框架进行网络请求,这种方式已经有点老旧了,配置和调用方式非常混乱,近几年刚刚出来的Fetch提供了一个更好的替代方法,它不仅提供了一种简单,合乎逻辑的方式来跨网络异步获取资源,而且可以很容易地被其他技术使用。



原文发布时间为:2018年06月10日
原文作者:浪里行舟
本文来源:  掘金  如需转载请联系原作者
相关文章
|
4月前
|
XML 前端开发 JavaScript
AJAX 工作原理
**AJAX**利用JavaScript与`XMLHttpRequest`异步通信,结合DOM操作、CSS样式和XML数据格式,实现页面无刷新更新。Google Suggest在2005年通过此技术提升了用户体验,用户输入时动态获取搜索建议,展示了AJAX的平台无关性和创新交互。
|
5月前
|
XML 前端开发 JavaScript
ajax原理是什么?如何实现?
ajax原理是什么?如何实现?
73 0
|
4月前
|
XML 前端开发 JavaScript
AJAX 工作原理
AJAX是一种利用XMLHttpRequest对象、JavaScript/DOM、CSS和XML进行异步数据交换的技术,实现浏览器和平台无关的动态Web界面。Google Suggest在2005年通过使用AJAX,实现了用户输入关键词时实时显示搜索建议的功能,极大提升了用户体验。
|
12天前
|
XML 前端开发 JavaScript
ajax运行原理
AJAX(Asynchronous JavaScript and XML)是一种使网页能够在不重新加载整个页面的情况下与服务器异步通信的技术。尽管名字中有“XML”,但它支持多种数据格式,如JSON、HTML和纯文本。用户行为触发AJAX请求后,通过创建`XMLHttpRequest`对象或使用现代浏览器中的`fetch` API来配置并发送HTTP请求。请求完成后,可以通过回调函数处理服务器返回的数据,更新网页内容。现代JavaScript推荐使用更简洁强大的`fetch` API来实现AJAX功能,广泛应用于动态网页和单页应用中,提升用户体验。
|
5月前
|
XML 前端开发 JavaScript
AJAX 工作原理
**AJAX**利用XMLHttpRequest与服务器异步交互数据,结合JavaScript/DOM处理显示,CSS样式设计及XML数据格式,实现平台无关的动态Web应用。Google Suggest于2005年通过AJAX技术提供实时搜索建议,增强了用户体验。
|
4月前
|
XML 前端开发 JavaScript
AJAX 工作原理
**AJAX**利用**XMLHttpRequest**进行异步数据交换,结合**JavaScript/DOM**更新页面,借助**CSS**样式和**XML**数据格式,实现跨平台的动态Web应用。谷歌的**Google Suggest**在2005年展示了AJAX的力量,用户输入时即刻获取搜索建议,无需刷新页面。
|
4月前
|
XML 前端开发 JavaScript
AJAX 工作原理
**AJAX**利用**XMLHttpRequest**进行异步数据交换,结合**JavaScript/DOM**更新页面,借助**CSS**样式呈现,有时使用**XML**传输数据,实现跨平台的Web交互。标志性应用是2005年**Google Suggest**,它在用户输入时动态提供搜索建议,展示了AJAX提升用户体验的能力。
|
5月前
|
XML 前端开发 JavaScript
AJAX 工作原理
**AJAX**利用JavaScript与`XMLHttpRequest`对象异步通信,结合DOM操作、CSS样式及XML数据格式,实现页面无刷新更新。Google Suggest在2005年借助AJAX技术,展示了动态输入建议功能,提升了用户体验。此技术跨浏览器、跨平台,促进了Web交互性的革命。
|
5月前
|
XML 前端开发 JavaScript
AJAX 工作原理
**AJAX**利用**XMLHttpRequest**进行异步数据交换,结合JavaScript/DOM操控页面,CSS美化,XML处理数据,实现平台无关的动态交互。Google Suggest(2005)是其典范,输入关键词即实时获取搜索建议,提升用户体验。
|
5月前
|
XML 前端开发 JavaScript
AJAX 工作原理
**AJAX**利用**XMLHttpRequest**进行异步数据交换,结合**JavaScript/DOM**更新页面,**CSS**处理样式,**XML**传输数据,实现跨平台的交互。谷歌的**Google Suggest**(2005)展示了AJAX的力量,它在用户输入时动态获取建议,提升Web界面的互动体验。