1.下载axios
npm i @nuxtjs/axios -s
2. 在nuxt.config.js中配置axios
modules: [
'@nuxtjs/axios',
],
此时, 就可以在组件中使用啦
async asyncData({$axios}) {
let { res } = await $axios.get(`https://xxx.com/api/xxx`)
console.log(res)
}
3. 配置axios的baseUrl, 拦截器
3.1 在~/plugins 创建 axios.js文件
配置:
export default function ({store, redirect, req, router, app: { $axios }}) {
// 数据访问前缀
$axios.defaults.baseURL = 'http://XXX/api';
if(process.server){
// 获取服务端的token
var token = getCookie.getcookiesInServer(req).token;
}
if(process.client){
// 获取客户端token
var token = getCookie.getcookiesInClient('token');
}
// request拦截器
$axios.onRequest(config => {
if(process.client){
// 客户端下,请求进度条开始
NProgress.start();
}
// 将获取到token加入到请求头中
config.headers.common['Authorization'] = token;
});
// response拦截器,数据返回后,可以先在这里进行一个简单的判断
$axios.interceptors.response.use(
response => {
if(process.client){
// 客户端下, 请求进度条结束
NProgress.done();
}
// return response
if(response.data.code == 401){
// 返回401,token验证失败,清除客户端cookie
Cookie.remove("token");
// 重定向到登录页面, 这里做一个判断,容错:req.url 未定义
if(req.url){
redirect("/sign?ref="+req.url)
}else{
redirect("/sign")
}
}else if(response.data.code == 404){
// 重定向到404页面
redirect("/")
}
else{
// 请求接口数据正常,返回数据
return response
}
},
error => {
if(process.client){
NProgress.done();
}
if(error.response.status == 500){
// http状态500,服务器内部错误,重定向到500页面
redirect("/500.htm")
}
if(error.response.status == 404){
// http状态500,请求API找不到,重定向到404页面
redirect("/404.html")
}
return Promise.reject(error.response) // 返回接口返回的错误信息
})
}
3.2 将axios.js添加到nuxt.config.js中,全局使用上面配置
plugins: [
'~/plugins/axios',
],
就可以在项目中使用啦
注意:nuxt.js中异步获取函数没有this,属性,具体看下方代码
// params: 页面路由相关信息
// $axios: 引入axios
// context:... 详见官方文档
https://zh.nuxtjs.org/api/context/
async asyncData({params, $axios}){
let [answer] = await Promise.all([
$axios.get("/userpage/answer_list/"+params.name)
]);
return {
answerData: answer.data.data,
}
}
axios配置使用先更到这里。
如有疑问请留言;或联系邮箱:[email protected]
欢迎访问:http://www.manbanzhen.top 、http://www.ofus.ink
转载请注明出处。