原生js实现Ajax
Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步刷新。这意味着可以在不重新加载整个网页的情况下,对网页的某个部分进行更新。
五步创建法
- 创建XMLHttpRequest对象
- 使用open方法设置和服务器的交换信息
- 设置发送的数据,开始和服务器端交互
- 注册事件
- 更新界面
get请求
1 | //步骤一:创建异步对象 |
post请求
1 | //步骤一:创建一个异步对象 |
将get请求和post请求封装
为了方便使用,我们可以将它们封装进方法里面,要用的时候,直接调用就好了。1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55ajax({
url:"getName.php",
type:"POST",
data:{name:"fox",age:20},
dataType:"json",
success:function(response,xml){
//此处放成功后执行的代码
},
fail:function(status){
//此处放失败后执行的代码
}
});
//开始封装
function ajax(options){
//获取所有参数
options = options || {};
options.type = (options.type || 'GET').toUpperCase();
options.dataType = options.dataType||"json";
var params = formatParams(options.data);
//创建异步对象
var xhr = new XMLHttpRequest();
//获取请求类型并发送
if(options.type = "GET"){
xhr.open('GET',options.url+'?'+params,true)
xhr.send()
}else{
xhr.oprn('post',options.url,true);
xhr.send(params)
}
//注册事件
xhr.onreadystatechange = function(){
if(xhr.readyState==4 && xhr.status ==200){
options.success && options.success(xhr.responseText)
}else{
options.fail && options.fail(status)
}
}
}
//格式化参数
function formatParams(data){
var arr = [];
for(var name in data){
arr.push(encodeURIComponent(name)+"="+encodeURIComponent(data[name]));
};
arr.push(("v="+Math.random()).replace("."));
return arr.join("&")
}