前言:ajax的知识相对比较简单,此文章仅表明鄙人的总结和理解,若有错漏,欢迎指正...javascript
Ajax的原理简单来讲经过XmlHttpRequest对象来向服务器发送异步请求,从服务器得到数据,而后用javascript来操做DOM而更新页面。
XMLHttpRequest是ajax的核心机制,是一种支持异步请求的技术。简单的说,也就是javascript能够及时向服务器提出请求和处理响应,而不阻塞用户。达到无刷新的效果。php
说人话就是:“HTTP协议的异步通讯”。java
那什么是同步,异步呢?
同步是阻塞模式,异步是非阻塞模式。
同步就是指一个进程在执行某个请求的时候,若该请求须要一段时间才能返回信息,那么这个进程将会一直等待下去,直到收到返回信息才继续执行下去;
异步是指进程不须要一直等下去,而是继续执行下面的操做,无论其余进程的状态。当有消息返回时系统会通知进程进行处理,这样能够提升执行的效率。面试
1) 建立一个XMLHttpRequest对象
2) 调用该对象的open方法
3) 若是是get请求,设置回调函数onreadystatechange = callback
4) Send
复制代码
1) 建立一个XMLHttpRequest对象
2) 调用该对象的open方法
3) 调用setRequestHeader(“Content-Type”, “application/x-www-form-urlencoded”);
4) 设置回调函数onreadystatechange = callback
5) Send
复制代码
<script type="text/javascript">
$('#bid').click(function(){
$.ajax({
url:'3.query.php',//地址
dataType:'json',//数据类型
type:'GET',//类型
timeout:2000,//超时
//请求成功
success:function(data,status){
//alert(data);
//alert(status);
},
//失败/超时
error:function(XMLHttpRequest,textStatus,errorThrown){
if(textStatus==='timeout'){
alert('请求超时');
setTimeout(function(){
alert('从新请求');
},2000);
}
//alert(errorThrown);
}
})
})
</script>
复制代码
语法:ajax
$.get(URL,callback);
复制代码
例子:json
$("button").click(function(){
$.get("demo_test.asp",function(data,status){
alert("Data: " + data + "\nStatus: " + status);
});
});
复制代码
语法:bash
$.post(URL,data,callback);
复制代码
例子:服务器
$("button").click(function(){
$.post("demo_test_post.asp",
{
name:"Donald Duck",
city:"Duckburg"
},
function(data,status){
alert("Data: " + data + "\nStatus: " + status);
});
});
复制代码
想要了解更多关于ajax的知识,可参考如下博客:app
面试题 —— Ajax的基本原理总结
总结 - Ajax工做原理和实现步骤异步
结语:以往都是看别人的博客进行学习技术,其中不乏有精华博客也有吊儿郎当的CV大法文章,因此决定将本身所学所用所整理的知识分享给你们,主要仍是想为了后浪们少走些弯路,多些正能量的博客,若有错漏,欢迎指正,仅但愿你们能在个人博客中学到知识,解决到问题,那么就足够了。谢谢你们!(转载请注明原文出处)