1. 使用ajax請求一個文件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<h1 id="content">.........</h1>
<button id="btn">點我讀取文件</button>
<script>
var content = document.getElementById('content');
var btn = document.getElementById('btn');
function ajax(method, url, data, successFn, failFn) {
let xhr = new XMLHttpRequest();
xhr.open(method, url);
xhr.send();
xhr.onreadystatechange = function() {
console.log(xhr,'==========')
if (xhr.readyState == '4') {
if (xhr.status == '200') {
//成功回調(diào)
successFn(xhr.responseText);
} else {
failFn(xhr.status);
}
}
};
}
function successFn(responTest) {
console.log(responTest, '成功');
content.innerText = responTest;
}
function failFn(status) {
console.log(status, '失敗');
}
btn.onclick = function(){
ajax('get', './1.txt', {}, successFn, failFn);
}
</script>
</body>
</html>
對應(yīng)的文件1.txt
hello world
2.使用promise 和 async await 來分別處理一個請求和兩個請求
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<h1 id="content">文件1內(nèi)容</h1>
<h1 id="content_one">文件2內(nèi)容</h1>
<button id="btn">點我讀取文件1</button>
<button id="btn_two">點我讀取文件2</button>
<button id="btn_three">點擊讀取文件1和文件2(先一后二)</button>
<button id="btn_four">讀取文件1和文件2(都讀取完畢再做處理)</button>
<button id="btn_five">讀取文件1和文件2(那個請求快處理哪個)</button>
<button id="btn_six">先后讀取文件1和文件2(async await)</button>
<script src="http://code.jquery.com/jquery-2.1.1-rc2.min.js"></script>
<script>
let content = document.getElementById('content');
let content_one = document.getElementById('content_one');
let btn = document.getElementById('btn');
let btn_two = document.getElementById('btn_two');
let btn_three = document.getElementById('btn_three');
let btn_four = document.getElementById('btn_four');
let btn_five = document.getElementById('btn_five');
let btn_six = document.getElementById('btn_six');
//包裝的ajax 用于請求數(shù)據(jù)
function ajaxPromise(url,method,data) {
var pro = new Promise(function(resolve, reject) {
var ajax = new XMLHttpRequest();
var method=method||"GET"
var data=data ||null
ajax.open(method, url);
ajax.send(data);
ajax.onreadystatechange = function() {
if (ajax.readyState == 4) {
if(ajax.status == '200'){
console.log(resolve,'======')
resolve(ajax.responseText);
}else{
reject(ajax.status);
}
}
}
})
return pro;
}
//1.使用promise then的鏈?zhǔn)秸{(diào)用的方式 傳入請求成功和失敗的回調(diào) 來執(zhí)行成功的邏輯和捕獲異常
btn.addEventListener('click',()=>{
ajaxPromise("./1.txt").then(function(msg) {
console.log(msg,'請求成功');
content.innerText = msg;
}, function(msg) {
console.log(msg,'請求失敗');
content.innerText = msg;
})
})
//2.使用async await方式來處理該請求 使用try catch來處理請求成功的邏輯和捕獲異常
btn_two.addEventListener('click',async ()=>{
try{
let res = await ajaxPromise("./1.json");
console.log(res,'哈哈哈哈哈哈');
let {success,data} = JSON.parse(res);
if(success){
console.log(data,'請求成功');
let {showColumnsMap} = data;
let listArr = [];
Object.keys(showColumnsMap).forEach((key)=>{
listArr.push(showColumnsMap[key])
})
console.log(listArr,'=====')
let contentDom = listArr.map((item)=>{
return `<div>${item}<div/>`
})
console.log(contentDom,'=====')
content_one.innerHTML = contentDom.join('');
}
}catch(error){
console.log(error,'請求失敗')
}
})
//3.使用promise的then的鏈?zhǔn)秸{(diào)用方式 先后發(fā)兩個請求 請求成功第一個文件后,再請求第二個文件 但凡第一個請求失敗了,第二個請求也就不會去觸發(fā) 被阻斷了
btn_three.addEventListener('click',()=>{
ajaxPromise("./1.txt").then(function(msg) {
console.log(msg,'第一個文件請求成功');
content.innerText = msg;
ajaxPromise('./1.json').then((res)=>{
let {success,data} = JSON.parse(res);
if(success){
console.log(data,'第二個文件請求成功');
let {showColumnsMap} = data;
let listArr = [];
Object.keys(showColumnsMap).forEach((key)=>{
listArr.push(showColumnsMap[key])
})
console.log(listArr,'=====')
let contentDom = listArr.map((item)=>{
return `<div>${item}<div/>`
})
console.log(contentDom,'=====')
content_one.innerHTML = contentDom.join('');
}
},(err)=>{
console.log(err,'第二個文件請求失敗')
})
}, function(msg) {
console.log(msg,'第一個文件請求失敗');
content.innerText = msg;
})
});
//4. 使用promise all的方式 請求兩個接口,都成功后對于請求到的數(shù)據(jù)進(jìn)行統(tǒng)一處理
btn_four.addEventListener('click',()=>{
Promise.all([ajaxPromise("./1.txt"),ajaxPromise('./1.json')]).then((res)=>{
console.log(res,'請求成功')
//處理第一個請求回來的數(shù)據(jù)
let msg1 = res[0];
content.innerText = msg1;
//處理第二個請求回來的數(shù)據(jù)
let dataObj = JSON.parse(res[1]);
console.log(dataObj,'=======');
let {data} = dataObj;
console.log(data,'第二個文件請求成功');
let {showColumnsMap} = data;
let listArr = [];
Object.keys(showColumnsMap).forEach((key)=>{
listArr.push(showColumnsMap[key])
})
console.log(listArr,'=====')
let contentDom = listArr.map((item)=>{
return `<div>${item}<div/>`
})
console.log(contentDom,'=====')
content_one.innerHTML = contentDom.join('');
},(err)=>{
console.log(err,'請求出錯')
})
});
//5. 使用promise race的方式 請求兩個接口,于先完成的請求到的數(shù)據(jù)進(jìn)行處理 如果某一個請求出錯了,不會影響另外一個請求
btn_five.addEventListener('click',()=>{
Promise.race([ajaxPromise("./11.txt"),ajaxPromise('./1.json')]).then((res)=>{
console.log(res,'請求成功');
let resArr = res.split(' ');
console.log(resArr,'===========')
console.log(resArr,'===========')
if(resArr.length<=2){
//處理第一個請求回來的數(shù)據(jù)
content.innerText = res;
}else{
let {success,data} = JSON.parse(res);
if(success){
//處理第二個請求回來的數(shù)據(jù)
console.log(data,'第二個文件請求成功');
let {showColumnsMap} = data;
let listArr = [];
Object.keys(showColumnsMap).forEach((key)=>{
listArr.push(showColumnsMap[key])
})
console.log(listArr,'=====')
let contentDom = listArr.map((item)=>{
return `<div>${item}<div/>`
})
console.log(contentDom,'=====')
content_one.innerHTML = contentDom.join('');
}
}
},(err)=>{
console.log(err,'請求出錯')
})
});
//6. 使用async await 的方式 哪個寫在前面哪個先請求,一個請求失敗,另一個也會被阻斷。 使用這樣的方式好處是在有異步回調(diào)嵌套的情況下比單純的使用promise看起來代碼邏輯和結(jié)構(gòu)更清晰,
//避免了回調(diào)嵌套回調(diào)的回調(diào)地獄問題,async await 的使用try catch來處理成功和捕獲異常
btn_six.addEventListener('click',async ()=>{
try{
let res2 = await ajaxPromise("./1.json");
console.log(res2,'=========');
if(res2){
let {success,data} = JSON.parse(res2);
if(success){
//處理第二個請求回來的數(shù)據(jù)
console.log(data,'第二個文件請求成功');
let {showColumnsMap} = data;
let listArr = [];
Object.keys(showColumnsMap).forEach((key)=>{
listArr.push(showColumnsMap[key])
})
console.log(listArr,'=====')
let contentDom = listArr.map((item)=>{
return `<div>${item}<div/>`
})
console.log(contentDom,'=====')
content_one.innerHTML = contentDom.join('');
}
}
let res1 = await ajaxPromise("./1.txt");
console.log(res1,'========');
if(res1){
//處理第一個請求回來的數(shù)據(jù)
content.innerText = res1;
}
}catch(error){
console.log(error,'請求出錯')
}
})
</script>
</body>
</html>
對應(yīng)的文件1.json
{
"data": {
"showColumnsMap": {
"keyval2": "幣種",
"keyval3": "會計月",
"inputstate": "錄入標(biāo)志",
"pk_task": "所屬任務(wù)",
"finalfilecount": "管理報告數(shù)量",
"pk_org": "報表主組織",
"pk_report": "報表",
"taskcheckstate": "任務(wù)審核狀態(tài)",
"inputperson": "錄入人",
"repcheckstate": "報表審核狀態(tài)",
"repcommitstate": "報表上報狀態(tài)",
"inputtime": "錄入時間",
"taskcommitstate": "任務(wù)上報狀態(tài)"
}
},
"success": true
}
以上實例即是ajax ,promise, async和await來處理異步的一些對比和分析。