Ajax常用封裝庫——Axios的使用
目錄
axios 是目前應用最為廣泛的 ajax 封裝庫
axios的特性有:
- 從瀏覽器中創(chuàng)建 xmlhttprequests
- 從 node.js 創(chuàng)建 http 請求
- 支持 promise api
- 攔截請求和響應
- 轉換請求數(shù)據和響應數(shù)據
- 取消請求
- 自動轉換 json 數(shù)據
- 客戶端支持防御 xsrf
使用axios時,需要通過使用script標簽引入:https://unpkg.com/axios/dist/axios.min.js
axios的中文網鏈接:axios中文網
axios api
向axios()傳遞相關配置來創(chuàng)建請求;
- axios(對象格式的配置選項)
- axios(url,config)
常用的配置項
- url:用于請求的服務器url
- method:創(chuàng)建請求時使用的方法
- baseurl:傳遞相對url前綴,將自動加在url前面
- headers:即將被發(fā)送的自定義請求頭
- params:即將與請求一起發(fā)送的url參數(shù)
- data:作為請求主體被發(fā)送的數(shù)據
- timeout:指定請求超時的毫秒數(shù)(0表示無超時時間)
- responsetype:表示服務器響應的數(shù)據類型,默認“json”
axios().then(function(response){ //正常請求的響應信息對象response }) .catch(function(error){ //捕獲的錯誤 })
代碼展示如下:
<script src="https://unpkg.com/axios/dist/axios.min.js"></script> <script> //使用axios方法 post請求 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 全局默認值的配置
axios.defaults.baseurl = 'https://xxx.xxx.com'; axios.defaults.headers.post['content-type'] = 'application/x-www-form-urlencode'
axios攔截器:在請求或響應被then或catch處理前攔截它們
axios 的請求攔截器
//axios 的請求攔截器 axios.interceptors.request.use(function(config){ //配置項config config.params = { id:2 //對配置項中的params進行更改,篩選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); }) //多個axios方法也可以攔截
axios 的響應攔截器
//axios 的響應攔截器 axios.interceptors.response.use(function(response){ return(response.data);//response里有很多值,選擇data即可 }) //axios 方法 axios("http://localhost:3000/liuyan") .then(function (res) { console.log(res);//response那里攔截了,已經將數(shù)據傳成data了 }) .catch(function (error) { console.log(error); })
axios的快速請求方法
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請求,添加數(shù)據 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對xmlhttprequest類型全面升級,使其變得更加易用、強大。
onload / onprogress
xml.onload 事件:只在請求完成時觸發(fā)
xml.onprogress 事件:只在請求進行中觸發(fā)
//xhr.onload事件:只在請求完成時觸發(fā) //xhr.onprogress事件:只在請求進行中觸發(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); //在周期性請求過程中,接收到的數(shù)據個數(shù) console.log(e.loaded); //接收數(shù)據的總個數(shù) console.log(e.total); } xhr.send(null);
response屬性
以對象的形式表述響應體,其類型取決于responsetype的值。根據responsetype的值,來通過特定的類型請求數(shù)據。
responsetype要在調用open()初始化請求之后,在調用send()發(fā)送請求到服務器之前設置才會有效。
//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常用封裝庫——axios的使用的詳細內容,更多關于ajax封裝庫axios的使用的資料請關注碩編程其它相關文章!