Nuxt Axios 模块读取状态码

Cod*_*ker 2 axios nuxt.js

我正在调用一个返回至少 2 个成功状态代码的 Rest API。正常的 200 OK 和 202 Accepted 状态代码。两者都在正文中返回一个内容。如果我在邮递员中执行我的电话,我可能会得到类似的信息

状态代码:202 已接受。使用正文“排队”或其他一些值 在此处输入图片说明 在此处输入图片说明 或者

状态代码:200 OK。带有正文“ValueOfSomeToken” 在此处输入图片说明 在我的 nuxt 应用程序中使用 axios 进行调用:

this.$axios.$get('/Controller/?id=1')
  .then((response)=>{
     if(response=='Queued'){
         //Do something
     }
     else if (response=='Expired'){
       //Do something
     }
     else{
       //Do something
     }
  })
  .catch((error)=>{
            console.log(error);
  });
Run Code Online (Sandbox Code Playgroud)

..有效,但我实际上想获取状态代码(因为 202 对正文响应还有其他值)

我不知道如何读取状态代码。

我尝试使用 (response,code) =>... 但是代码什么都不是。

Sey*_*sen 10

您可以使用非$前缀函数this.$axios.get()代替this.$axios.$get()来获得完整的响应

// Normal usage with axios
let { data } = await $axios.get('...'));

// Fetch Style
let data = await $axios.$get('...');
Run Code Online (Sandbox Code Playgroud)

来源


div*_*ine 6

status codes您可以从响应对象中提取axios

如果打印响应对象(如下图所示),您可以看到响应对象内的所有对象。其中之一是status object

在此输入图像描述

response.status将为您提供从服务器发送的状态代码

axios.get("http://localhost:3000/testing").then((response)=>{
    console.log("response ",response);
    if(response.status == 200){
        //do something
    }
    else if(response.status == 202){
        //do something
    }
    else if(response.status == 301){
        //do something
    }
}).catch((err)=>{
    console.log("err11 ",err);
})
Run Code Online (Sandbox Code Playgroud)

在服务器端,您可以使用res.status()方法显式发送任何状态代码,有关更多详细信息,请参阅此文档

app.get('/testing',(req, res)=> {
  res.status(202).send({"res" : "hi"});
});
Run Code Online (Sandbox Code Playgroud)

更新:

默认情况下,@nuxtjs/axios返回response.data.then((response))

$axios.onResponse事件将有权访问完整的响应对象。

您需要设置一个拦截器来拦截$axios.onResponse事件并修改响应对象

在plugin目录下创建一个插件,plugin/axios.js

更新 以下plugins部分plugins : ['~/plugins/axios']nuxt.config.js

export default function ({ $axios, redirect }) {
    $axios.onResponse(res=>{
        console.log("onResponse ", res);
        res.data.status = res.status;        
        return res;
    })
}
Run Code Online (Sandbox Code Playgroud)

在此拦截器中,res object您将拥有所有值(如我的第一个屏幕截图所示)。但这res object并没有按原样返回,只是res.data返回到我们的程序。

我们可以更新里面的内容res.data,然后返回res object如我的程序所示res.data.status = res.status;

现在,当axios返回时,res.data我们将可以访问承诺中对象res.data.status的值response.then((response))

response.status您可以使用内部访问状态this.$axios

this.$axios.$get("url").then((response) =>{
    console.log("status ",response.status);
}).catch((err) => {
    console.log("res err ",err);
});
Run Code Online (Sandbox Code Playgroud)