首先介绍一下两个概念:
一、同步请求和异步请求
注意这里的同步和我们日常生活中的同步有点区别,这里的同步包含一个一前一后的概念,只有前一个动作完成后,后一个动作才能开始,否则后一个动作会一直阻塞在那,直到等到前一个动作顺利完成。而异步就像是两个线程并发执行,或者说同时执行,不存在阻塞现象。
二、Ajax技术
Ajax是Asynchronous Javascript And XML的缩写,即异步JavaScript和XML。Ajax的出现是Web技术发展中的一大飞跃,因为在此之前都只能发送同步请求,而在此之后可以发送异步请求。就比如说我们在购物网站中,当我们选好商品后,提交时发现某个商品数量少了,这是我们要增加该商品的数量时,就要向后台发送请求,如果我们发送同步请求,首先要跳到后台,然后再跳回前台,这样,前面所选中的信息都丢失了,得不偿失。而Ajax正好可以解决这个问题,在发送请求的同时,页面不发生跳转,只根据返回值做局部更新。
下面介绍一下Ajax的使用方法:
一般使用Ajax通常有两种方法,即原始的Ajax方法和JQuery中的$.ajax()方法,下面简单介绍:
一、js中原始的Ajax方法
注意两种方法都应该写在JavaScript当中。原始Ajax主要步骤如下:
var req2;
if (window.XMLHttpRequest) {
req2 = new XMLHttpRequest();// IE7, Firefox, Opera支持
} else if (window.ActiveXObject) {
req2 = new ActiveXObject("Microsoft.XMLHTTP");// IE5,IE6支持
}
req2.open("get", url, true);
alert("修改成功");
req2.onreadystatechange = callback;
req2.send(null);
function callback() {
if (req2.readyState == 4 && req2.status == 200) {
return "OK";
} else {
return "error";
}
}
二、JQuery中的$.ajax()方法
$.ajax({
url:"../PayAndDelete",
type:"post",
data:{
condition : "evaluate",
ord_id : ord_id,
pkscore : pkscore,
spscore : spscore,
atscore : atscore,
goscore : goscore,
tags : tags,
def_text : def_text,
words : words,
anony : anony
},
success:function(data){
},
error:function(){
}
});