Axios是一個基于Promise的HTTP客戶端,適用于瀏覽器和node.js環境,同時也是Vue.js推薦的AJAX庫。Axios能讓我們更方便地進行請求和響應攔截。
在Vue中使用Axios十分簡單,我們只需要在Vue項目中使用npm install axios下載Axios庫即可,并在需要使用的vue文件中引入Axios:
import axios from 'axios'
在Vue.js的mounted()生命周期函數內使用Axios發送請求:
mounted() {
axios.get('xxx').then(response =>{
console.log(response)
}).catch(error =>{
console.log(error)
})
}
這段代碼中,我們使用Axios發送了一個GET請求,在請求成功時打印出響應結果,在請求失敗時打印出錯誤信息。同時,我們也可以使用Axios發送POST請求,在請求體中添加數據:
axios.post('xxx', { param1: 'value1', param2: 'value2' })
.then(response =>{
console.log(response)
})
.catch(error =>{
console.log(error)
})
}
可以看到,使用Axios發送請求非常簡單,同時Axios也提供了攔截器實現請求和響應攔截,在請求發送前或者響應返回后可以做出一些統一的處理。例如,我們可以在請求頭中加入Token認證信息:
axios.interceptors.request.use(config =>{
config.headers.Authorization = window.localStorage.getItem('token')
return config
}, error =>{
return Promise.reject(error)
})
這段代碼中,我們使用Axios的request攔截器,在請求發送前在請求頭中加入了Authorization信息,這樣每個請求都會在請求頭中加入Token認證信息。在架構較為復雜的項目中,統一處理請求和響應攔截是非常有用的。
上一篇axios vue 全局
下一篇awsome vue