axios 是目前應(yīng)用最為廣泛的 ajax 封裝庫(kù)
axios的特性有:
- 從瀏覽器中創(chuàng)建 xmlhttprequests
- 從 node.js 創(chuàng)建 http 請(qǐng)求
- 支持 promise api
- 攔截請(qǐng)求和響應(yīng)
- 轉(zhuǎn)換請(qǐng)求數(shù)據(jù)和響應(yīng)數(shù)據(jù)
- 取消請(qǐng)求
- 自動(dòng)轉(zhuǎn)換 json 數(shù)據(jù)
- 客戶端支持防御 xsrf
使用axios時(shí),需要通過(guò)使用script標(biāo)簽引入:https://unpkg.com/axios/dist/axios.min.js
axios的中文網(wǎng)鏈接:axios中文網(wǎng)
axios api
向axios()傳遞相關(guān)配置來(lái)創(chuàng)建請(qǐng)求;
- axios(對(duì)象格式的配置選項(xiàng))
- axios(url,config)
常用的配置項(xiàng)
- url:用于請(qǐng)求的服務(wù)器url
- method:創(chuàng)建請(qǐng)求時(shí)使用的方法
- baseurl:傳遞相對(duì)url前綴,將自動(dòng)加在url前面
- headers:即將被發(fā)送的自定義請(qǐng)求頭
- params:即將與請(qǐng)求一起發(fā)送的url參數(shù)
- data:作為請(qǐng)求主體被發(fā)送的數(shù)據(jù)
- timeout:指定請(qǐng)求超時(shí)的毫秒數(shù)(0表示無(wú)超時(shí)時(shí)間)
- responsetype:表示服務(wù)器響應(yīng)的數(shù)據(jù)類(lèi)型,默認(rèn)“json”
axios().then(function(response){ //正常請(qǐng)求的響應(yīng)信息對(duì)象response }) .catch(function(error){ //捕獲的錯(cuò)誤 })
代碼展示如下:
<script src="https://unpkg.com/axios/dist/axios.min.js"></script> <script> //使用axios方法 post請(qǐng)求 axios({ url:"/pinglun", method:"post", baseurl:"http://localhost:3000", header:{ "content-type":"application/json" }, data:{ "content":"well", "lyid":4 }, timeout:1000, }).then(function(res){ console.log(res.data); }).catch(function(error){ console.log(error); }) </script>
axios 全局默認(rèn)值的配置
axios.defaults.baseurl = 'https://xxx.xxx.com'; axios.defaults.headers.post['content-type'] = 'application/x-www-form-urlencode'
axios攔截器:在請(qǐng)求或響應(yīng)被then或catch處理前攔截它們
axios 的請(qǐng)求攔截器
//axios 的請(qǐng)求攔截器 axios.interceptors.request.use(function(config){ //配置項(xiàng)config config.params = { id:2 //對(duì)配置項(xiàng)中的params進(jìn)行更改,篩選id=2 } return config;//要有返回值 }) //axios 方法 axios("http://localhost:3000/liuyan") .then(function(res){ console.log(res.data); }) .catch(function(error){ console.log(error); }) //axios 方法 axios("http://localhost:3000/pinglun") .then(function (res) { console.log(res.data); }) .catch(function (error) { console.log(error); }) //多個(gè)axios方法也可以攔截
axios 的響應(yīng)攔截器
//axios 的響應(yīng)攔截器 axios.interceptors.response.use(function(response){ return(response.data);//response里有很多值,選擇data即可 }) //axios 方法 axios("http://localhost:3000/liuyan") .then(function (res) { console.log(res);//response那里攔截了,已經(jīng)將數(shù)據(jù)傳成data了 }) .catch(function (error) { console.log(error); })
axios的快速請(qǐng)求方法
axios.get(url[,config])
//axios.get(url[,config]) axios.get("http://localhost:3000/liuyan?id=2") .then(function(res){ console.log(res.data); }) axios.get("http://localhost:3000/liuyan",{ params:{ id:1 } }).then(function(res){ console.log(res.data); })
axios.post(url[,data[,config]])
//axios.post(url[,data[,config]]) , post請(qǐng)求,添加數(shù)據(jù) axios.post("http://localhost:3000/users",{ name:"laowang", age:23, class:1 })
axios.delete(url[,config])
//axios.delete(url[,config]) axios.delete("http://localhost:3000/liuyan",{ params:{ id:5 } })
axios.put(url[,data[,config]])
//axios.put(url[,data[,config]]) axios.put("http://localhost:3000/liuyan",{ name:"wangshisan", id:11 })
xmlhttprequest2.0,html5對(duì)xmlhttprequest類(lèi)型全面升級(jí),使其變得更加易用、強(qiáng)大。
onload / onprogress
xml.onload 事件:只在請(qǐng)求完成時(shí)觸發(fā)
xml.onprogress 事件:只在請(qǐng)求進(jìn)行中觸發(fā)
//xhr.onload事件:只在請(qǐng)求完成時(shí)觸發(fā) //xhr.onprogress事件:只在請(qǐng)求進(jìn)行中觸發(fā) var xhr = new xmlhttprequest(); xhr.open("get","http://localhost:3000/pinglun"); xhr.onload = function(){ console.log("load:",this.readystate); }; xhr.onprogress = function(e){ console.log("progress:",this.readystate); //在周期性請(qǐng)求過(guò)程中,接收到的數(shù)據(jù)個(gè)數(shù) console.log(e.loaded); //接收數(shù)據(jù)的總個(gè)數(shù) console.log(e.total); } xhr.send(null);
response屬性
以對(duì)象的形式表述響應(yīng)體,其類(lèi)型取決于responsetype的值。根據(jù)responsetype的值,來(lái)通過(guò)特定的類(lèi)型請(qǐng)求數(shù)據(jù)。
responsetype要在調(diào)用open()初始化請(qǐng)求之后,在調(diào)用send()發(fā)送請(qǐng)求到服務(wù)器之前設(shè)置才會(huì)有效。
//xmlhttprequest之前的response返回 //responsetext // responsexml var xhr = new xmlhttprequest(); xhr.open("get","http://localhost:3000/pinglun"); xhr.onload = function(){ var data = json.parse(this.responsetext); console.log(data); } xhr.send(null); // xhr2.0新增的response屬性 // response // responsetype var xhr = new xmlhttprequest(); xhr.open("get","http://localhost:3000/liuyan"); xhr.responsetype = "json"; xhr.onload = function(){ console.log(this.response); } xhr.send(null)
以上就是ajax常用封裝庫(kù)——axios的使用的詳細(xì)內(nèi)容,更多關(guān)于ajax封裝庫(kù)axios的使用的資料請(qǐng)關(guān)注碩編程其它相關(guān)文章!