溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

VUE 更好的 ajax 上傳處理 axios.js實現(xiàn)代碼

發(fā)布時間:2020-09-04 17:05:17 來源:腳本之家 閱讀:214 作者:NowTheFuture 欄目:web開發(fā)

vue更新到2.0之后,作者就宣告不再對vue-resource更新,而是推薦的axios,前一段時間用了一下,現(xiàn)在說一下它的基本用法。

首先就是引入axios,如果你使用es6,只需要安裝axios模塊之后

import axios from 'axios';
//安裝方法
npm install axios
//或
bower install axios

當然也可以用script引入

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

axios提供了一下幾種請求方式

axios.request(config)

axios.get(url[, config])

axios.delete(url[, config])

axios.head(url[, config])

axios.post(url[, data[, config]])

axios.put(url[, data[, config]])

axios.patch(url[, data[, config]])

這里的config是對一些基本信息的配置,比如請求頭,baseURL,當然這里提供了一些比較方便配置項

//config
import Qs from 'qs'
{
 //請求的接口,在請求的時候,如axios.get(url,config);這里的url會覆蓋掉config中的url
 url: '/user',

 // 請求方法同上
 method: 'get', // default
 // 基礎(chǔ)url前綴
 baseURL: 'https://some-domain.com/api/',
  
    
 transformRequest: [function (data) {
  // 這里可以在發(fā)送請求之前對請求數(shù)據(jù)做處理,比如form-data格式化等,這里可以使用開頭引入的Qs(這個模塊在安裝axios的時候就已經(jīng)安裝了,不需要另外安裝)
  data = Qs.stringify({});
  return data;
 }],

 transformResponse: [function (data) {
  // 這里提前處理返回的數(shù)據(jù)

  return data;
 }],

 // 請求頭信息
 headers: {'X-Requested-With': 'XMLHttpRequest'},

 //parameter參數(shù)
 params: {
  ID: 12345
 },

 //post參數(shù),使用axios.post(url,{},config);如果沒有額外的也必須要用一個空對象,否則會報錯
 data: {
  firstName: 'Fred'
 },

 //設(shè)置超時時間
 timeout: 1000,
 //返回數(shù)據(jù)類型
 responseType: 'json', // default


}

有了配置文件,我們就可以減少很多額外的處理代碼也更優(yōu)美,直接使用

axios.post(url,{},config)
  .then(function(res){
    console.log(res);
  })
  .catch(function(err){
    console.log(err);
  })
//axios請求返回的也是一個promise,跟蹤錯誤只需要在最后加一個catch就可以了。
//下面是關(guān)于同時發(fā)起多個請求時的處理

axios.all([get1(), get2()])
 .then(axios.spread(function (res1, res2) {
  // 只有兩個請求都完成才會成功,否則會被catch捕獲
 }));

最后還是說一下配置項,上面講的是額外配置,如果你不想另外寫也可以直接配置全局

axios.defaults.baseURL = 'https://api.example.com';
axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';

//當然還可以這么配置
var instance = axios.create({
 baseURL: 'https://api.example.com'
});

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI