【前端Vue】axios

1. axios的功能和特點(diǎn)

  1. 在瀏覽器中發(fā)送 XMLHttpRequests 請(qǐng)求心例;

  2. node.js 中發(fā)送 http請(qǐng)求召嘶;

  3. 支持 Promise API胡诗;

  4. 攔截請(qǐng)求和響應(yīng)摊趾;

  5. 攔截請(qǐng)求和響應(yīng)顽频。

1.1 axios支持多種請(qǐng)求方式

  1. axios(config);

  2. axios.request(config);

  3. axios.get(url[, config]);

  4. axios.delete(url[, config]);

  5. axios.head(url[, config]);

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

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

  8. axios.patch(url[, data[, config]])肛著。

2. axios的基本使用

2.1 安裝 axios

  1. 使用 npm install axios --save 安裝axios圆兵。

2.2 在main.js中導(dǎo)入

import axios from 'axios'

2.3 使用 axios 發(fā)送簡(jiǎn)單請(qǐng)求

  1. axios發(fā)送請(qǐng)求默認(rèn)返回的是一個(gè) Promise對(duì)象。使用 Promise對(duì)象調(diào)用 then方法處理返回結(jié)果枢贿。

  2. axios默認(rèn)發(fā)送的是一個(gè) GET請(qǐng)求殉农。

/**
 * 發(fā)送請(qǐng)求,
 * 會(huì)不會(huì)出現(xiàn)跨域?
 * 默認(rèn)發(fā)送的是get請(qǐng)求
 */
axios({
  url: 'http://123.207.32.32:8000/home/multidata',
  methods: 'get'
}).then(value => {
  console.log(value)
})

axios.get('http://123.207.32.32:8000/home/multidata').then(
  value => {
    console.log(value)
  }
)
發(fā)送請(qǐng)求的時(shí)候傳遞參數(shù)
axios({
    url:'http://123.207.32.32:8000/home/multidata',
    params:{
        type:'pop',
        page:1
    }
})

2.4 全局配置

  1. 事實(shí)上, 在開(kāi)發(fā)中可能很多參數(shù)都是固定的局荚,這個(gè)時(shí)候我們可以進(jìn)行一些抽取, 也可以利用axiox的全局配置超凳。
axios.defaults.baseURL = ‘xxx.xxx.xxx.xxx:8000’
axios.defaults.headers.post[‘Content-Type’] = ‘a(chǎn)pplication/x-www-form-urlencoded’
axios.defaults.timeout = 5000

2.5 axios常見(jiàn)的配置選項(xiàng)

  1. 請(qǐng)求地址 url: '/user';

  2. 請(qǐng)求類型 method: 'get';

  3. 請(qǐng)根路徑baseURL: 'http://www.mt.com/api';

  4. 請(qǐng)求前的數(shù)據(jù)處理transformRequest:[function(data){}];

  5. 請(qǐng)求后的數(shù)據(jù)處理transformResponse: [function(data){}];

  6. 自定義的請(qǐng)求頭headers:{'x-Requested-With':'XMLHttpRequest'};

  7. URL查詢對(duì)象params:{ id: 12 };

  8. 查詢對(duì)象序列化函數(shù)paramsSerializer: function(params){ };

  9. 請(qǐng)求體 request body data: { key: 'aa'};

  10. 超時(shí)設(shè)置ms timeout: 1000;

  11. 跨域是否帶 Token withCredentials: false;

  12. 自定義請(qǐng)求處理 adapter: function(resolve, reject, config){};

  13. 身份驗(yàn)證信息 auth: { uname: '', pwd: '12'};

  14. 響應(yīng)的數(shù)據(jù)格式 json / blob /document /arraybuffer / text / stream;

  15. 響類型 responseType: 'json';

2.6 axios發(fā)送 并發(fā)請(qǐng)求

  1. 有時(shí)我們可能需要同時(shí)發(fā)送 多個(gè)請(qǐng)求,可以使用axios.all()耀态,可以放入多個(gè)請(qǐng)求的數(shù)組轮傍,axios.all([])返回結(jié)果是一個(gè)數(shù)組,使用 axios.spread可將數(shù)組[val1,val2]進(jìn)行解構(gòu)首装。
axios.all([
  axios({
    url: 'http://123.207.32.32:8000/home/multidata'
  })
  ,
  axios({
    url: 'http://123.207.32.32:8000/home/multidata',
    params: {
      type: 'pop',
      page: 4
    }
  })
  /!* 對(duì)返回的結(jié)果數(shù)組進(jìn)行展開(kāi) *!/
]).then(value => {
  console.log(value[0]);
  console.log(value[1]);
})

2.7 axios發(fā)送get請(qǐng)求傳遞參數(shù)的幾種方式

axios發(fā)送get請(qǐng)求傳遞參數(shù)的幾種方式

3. axios的實(shí)例和模塊的封裝

  1. src下創(chuàng)建一個(gè) network/request.js创夜,在該文件中封裝axios模塊:
import axios from 'axios'

export default function (config) {
  // 創(chuàng)建一個(gè)新的axios實(shí)例
  const instance = axios.create({
    baseURL: 'http://152.136.185.210:7878/api/m5',
    timeout: 5000
  })
  // 返回請(qǐng)求對(duì)象 返回一個(gè) Promise 對(duì)象
  return instance(config)
}

4. axios 攔截器的使用

4.1 請(qǐng)求攔截可以做的幾件事

  1. 當(dāng)發(fā)送網(wǎng)絡(luò)請(qǐng)求時(shí),頁(yè)面中希望添加一個(gè) loading的組件仙逻,作為動(dòng)畫(huà)驰吓;

  2. 某些請(qǐng)求要求用戶必須登錄,判斷用戶是否有token如果沒(méi)有token則跳轉(zhuǎn)到login頁(yè)面系奉。

  3. 對(duì)請(qǐng)求參數(shù)進(jìn)行序列化檬贰。

  4. 當(dāng)出現(xiàn)請(qǐng)求錯(cuò)誤時(shí),可以將頁(yè)面跳轉(zhuǎn)到一個(gè)錯(cuò)誤頁(yè)面中缺亮。

/**
   * 請(qǐng)求攔截器
   */
  instance.interceptors.request.use(
    config => {
      // 請(qǐng)求成功時(shí)
      console.log(config)
      /**
       *  可能在這里進(jìn)行的處理
       *    1. 需要檢查config的配置
       *    2. 在請(qǐng)求過(guò)程中的動(dòng)畫(huà)
       *    3. 某些網(wǎng)絡(luò)請(qǐng)求是必須攜帶一些特殊的信息 如 token
       */
      console.log(config.headers)

      return config // 需要將config作為返回值返回
    },
    err => {
      // 請(qǐng)求失敗的時(shí)候
      console.log(err)
    }
  )

4.2 響應(yīng)攔截器主要可以做什么翁涤?

  1. 響應(yīng)的成功攔截中,主要進(jìn)行數(shù)據(jù)的過(guò)濾瞬内。

  2. 響應(yīng)的失敗攔截中迷雪,可以根據(jù) status 判斷報(bào)錯(cuò)的錯(cuò)誤碼,跳轉(zhuǎn)到不同的錯(cuò)誤頁(yè)面虫蝶。

/**
   * 響應(yīng)攔截器
   *  對(duì)響應(yīng)結(jié)果進(jìn)行的處理
   */
  instance.interceptors.response.use(
    result => {
      // 這里會(huì)將結(jié)果進(jìn)行攔截
      return result.data
      // console.log(result)
    },
    err => {

    }
  )

5. 一個(gè)簡(jiǎn)單request.js請(qǐng)求模塊的封裝

import axios from 'axios'

export default function (config) {
  // 創(chuàng)建一個(gè)新的axios實(shí)例
  const instance = axios.create({
    baseURL: 'http://152.136.185.210:7878/api/m5',
    timeout: 5000
  })

  /**
   * 請(qǐng)求攔截器
   */
  instance.interceptors.request.use(
    config => {
      // 請(qǐng)求成功時(shí)
      console.log(config)
      /**
       *  可能在這里進(jìn)行的處理
       *    1. 需要檢查config的配置
       *    2. 在請(qǐng)求過(guò)程中的動(dòng)畫(huà)
       *    3. 某些網(wǎng)絡(luò)請(qǐng)求是必須攜帶一些特殊的信息 如 token
       */
      console.log(config.headers)

      return config // 需要將config作為返回值返回
    },
    err => {
      // 請(qǐng)求失敗的時(shí)候
      console.log(err)
    }
  )

  /**
   * 響應(yīng)攔截器
   *  對(duì)響應(yīng)結(jié)果進(jìn)行的處理
   */
  instance.interceptors.response.use(
    result => {
      // 這里會(huì)將結(jié)果進(jìn)行攔截
      return result.data
      // console.log(result)
    },
    err => {

    }
  )

  // 返回請(qǐng)求對(duì)象 返回一個(gè) Promise 對(duì)象
  return instance(config)
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末章咧,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子能真,更是在濱河造成了極大的恐慌赁严,老刑警劉巖扰柠,帶你破解...
    沈念sama閱讀 218,607評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異疼约,居然都是意外死亡卤档,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門程剥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)劝枣,“玉大人,你說(shuō)我怎么就攤上這事织鲸√蛱冢” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,960評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵搂擦,是天一觀的道長(zhǎng)稳诚。 經(jīng)常有香客問(wèn)我,道長(zhǎng)瀑踢,這世上最難降的妖魔是什么扳还? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,750評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮橱夭,結(jié)果婚禮上氨距,老公的妹妹穿的比我還像新娘。我一直安慰自己徘钥,他們只是感情好衔蹲,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著呈础,像睡著了一般。 火紅的嫁衣襯著肌膚如雪橱健。 梳的紋絲不亂的頭發(fā)上而钞,一...
    開(kāi)封第一講書(shū)人閱讀 51,604評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音拘荡,去河邊找鬼臼节。 笑死,一個(gè)胖子當(dāng)著我的面吹牛珊皿,可吹牛的內(nèi)容都是我干的网缝。 我是一名探鬼主播,決...
    沈念sama閱讀 40,347評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼蟋定,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼粉臊!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起驶兜,我...
    開(kāi)封第一講書(shū)人閱讀 39,253評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤扼仲,失蹤者是張志新(化名)和其女友劉穎远寸,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體屠凶,經(jīng)...
    沈念sama閱讀 45,702評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡驰后,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了矗愧。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片灶芝。...
    茶點(diǎn)故事閱讀 40,015評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖唉韭,靈堂內(nèi)的尸體忽然破棺而出夜涕,到底是詐尸還是另有隱情,我是刑警寧澤纽哥,帶...
    沈念sama閱讀 35,734評(píng)論 5 346
  • 正文 年R本政府宣布钠乏,位于F島的核電站,受9級(jí)特大地震影響春塌,放射性物質(zhì)發(fā)生泄漏晓避。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評(píng)論 3 330
  • 文/蒙蒙 一只壳、第九天 我趴在偏房一處隱蔽的房頂上張望俏拱。 院中可真熱鬧,春花似錦吼句、人聲如沸锅必。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,934評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)搞隐。三九已至,卻和暖如春远搪,著一層夾襖步出監(jiān)牢的瞬間劣纲,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,052評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工谁鳍, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留癞季,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,216評(píng)論 3 371
  • 正文 我出身青樓倘潜,卻偏偏與公主長(zhǎng)得像绷柒,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子涮因,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容