溫馨提示×

溫馨提示×

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

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

如何在Vue項目中使用axios

發布時間:2021-03-22 16:48:14 來源:億速云 閱讀:258 作者:Leah 欄目:web開發

本篇文章為大家展示了如何在Vue項目中使用axios,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

Axios 是一個用于實現網絡數據請求的JavaScript庫,可以用在網頁和 node.js 中,用于創建 XMLHttpRequests,vue官方支持使用axios代替vue--resourse來實現網絡數據請求。

使用前需要在你的項目中安裝axios,例如通過npm安裝庫:

npm install --save axios

接著在項目中引入axios:

import axios from 'axios'

1、get請求

直接使用axios的全局變量來調用get方法,get中第一個參數傳遞url,第二個參數是相關配置,在其中可以傳遞params參數(參數以?形式加在url末尾),進行header的設置等。使用.then接收返回值,可以采用函數來處理返回結果res,其中res.data或者res.body是返回的數據。使用.catch捕獲異常,并可以打印錯誤信息參數error。

axios.get('data/zodiac.json',{
 params:{
  id:"101"
 },
 header:{
  token:"axios"
 }
}).then(res =>{
 this.msg=res.data;
}).catch(error =>{
 console.log(error);
})

2、post請求

post方法調用、回掉、異常捕獲的使用與get類似。不同的是其參數分為三個,第一個是url地址,第二個是要傳遞的數據,第三個是傳輸選項配置。與get方法不同,post專門使用第二個參數進行數據傳遞,而不像get中將數據設置在配置選項params中。

axPost(){
 axios.post('./data/test.php',    //url
  {                 //發送的數據
   userId:'105'
  },
  {                 //option選項
   headers:{
    token:"axPost"
   }
  }
 ).then(res =>{            //接收結果
  this.msg=res.data;
 }).catch(err=>{           //處理錯誤
  this.msg=err;
 })
}

3、HTTP請求

也可以直接使用http進行數據請求,直接進行url、method、data、headers、params等的設置,例如使用http發送post請求:

axios({
 url:"http://localhost:63342/Web/Learning/Javascript/Vue/VueStart/data/zodiac.json",
 method:"post",
 data:{
  userId:"106"
 },
 headers:{
  token:"axHttp"
 }
}).then(res=>{
 this.msg=res.data;
})

4、攔截器

axios也提供了在網絡請求發送前與數據返回時進行攔截的函數interceptors,以便進行相關處理。例如在發送前使用request.use攔截,進行你想要的執行的操作后再將config返回出去,在請求返回時使用response.use進行攔截,操作后再將結果返回:

axios.interceptors.request.use(config =>{
 console.log("axois請求");
 return config;
});
axios.interceptors.response.use(res =>{
 console.log("axois回調");
 return res;
})

上述內容就是如何在Vue項目中使用axios,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女