【问题标题】:Unable to use an axios plugin in nuxt无法在 nuxt 中使用 axios 插件
【发布时间】:2020-04-02 02:50:18
【问题描述】:

我正在尝试按照here 的描述将 Axios 插件添加到 Nuxt,但它似乎不起作用。

这是我的plugins/axios.js 文件...

export default function({ $axios }) {
  console.log('Im in the axios plugin')
  $axios.defaults.baseURL = `https://localhost:5001/api`
  $axios.defaults.headers = {
    Accept: 'application/json',
    'Content-Type': 'application/json'
  }
  $axios.onRequest((config) => {
    console.log('Making request to ' + config.url)
  })
}

这是我的nuxt.config.js

plugins: ['~/plugins/axios'],
modules: ['@nuxtjs/axios']

这就是我在一个名为 services/BookService.js 的文件中使用 Axios 的地方:

import axios from 'axios'

export default {
  getBooks() {
    return axios.get('/Home')
  },
  getBooksFiltered(payload) {
    return axios.post('/Home/Filters', payload)
  }
}

我从我的插件中得到console.log('Im in the axios plugin'),但没有别的。 $axios.onRequest 似乎没有运行,baseURL 在触发getBooksFiltered 时似乎设置不正确。当它尝试访问地址http://localhost:3000/Home/Filters 时,我得到一个404。如我的插件中所述,地址应为https://localhost:5001/api/Home/Filters

我也在nuxt.config.js 中尝试了以下方法,但它不起作用:

axios: {
  baseURL: 'https://localhost:5001/api'
}

有什么想法吗?

编辑

我已根据以下建议将services/BookService.js 修改为以下内容...

export default {
  getBooks(axios) {
    console.log('Im in getBooks')
    return axios.get('/Home')
  }
}

我的 api 调用的操作请求如下......

import BookService from '~/services/BookService.js'

export const fetchBooks = (context) => {
  console.log('Im in fetchBooks action')
  return BookService.getBooks(this.$axios)
    .then((response) => {
      context.commit('SET_BOOKS', response.data.booksList)
    })
    .catch((error) => {
      console.log(error)
    })
}

还有我在组件中调用动作的方法...

async fetch({ store, error }) {
  try {
    console.log('Im in index -> fetch')
    await store.dispatch('fetchBooks')
  } catch (e) {
    error({
      statusCode: 503,
      message: 'Unable to fetch books at this time'
    })
  }
}

我知道我可能错误地将 async/await 与 Promise 混合在一起,但我不认为这是导致此问题的原因。

控制台返回以下...

我的网络选项卡包含对http://localhost:3000/ 的单个请求,这似乎不正确。根据插件和操作中指定的地址,它应该是https://localhost:5001/api/Home。它也永远不会进入$axios.onRequest

【问题讨论】:

    标签: javascript vue.js axios nuxt.js


    【解决方案1】:

    axios-module 在 Nuxt 应用实例上设置了一个 Axios 实例。当您从axios 导入 Axios 并直接使用它时,您并没有使用之前设置的 Axios 实例。

    要解决此问题,您可以从 window.$nuxt.$axios 引用预配置的 Axios 实例(仅在浏览器中),或者设置您的服务以将 Axios 实例作为参数:

    // services/BookService.js
    export default axios => ({
      getBooks() {
        return axios.get('/Home')
      },
      getBooksFiltered(payload) {
        return axios.post('/Home/Filters', payload)
      }
    })
    
    // store.js
    import BookService from '~/services/BookService.js'
    
    export default {
      actions: {
        async getBooks({ commit }) {
          const books = await new BookService(this.$axios).getBooks()
          commit('SET_BOOKS', books)
        }
      }
    }
    

    nuxt-community/axios-module #28的另一个解决方案:

    ~/plugins/axios-port.js

    import { setClient } from '~/services/apiClient'
    
    export default ({ app, store }) => {
      setClient(app.$axios)
    }
    

    ~/services/apiClient.js

    let client
    
    export function setClient (newclient) {
      client = newclient
    }
    
    // Request helpers
    const reqMethods = [
      'request', 'delete', 'get', 'head', 'options', // url, config
      'post', 'put', 'patch' // url, data, config
    ]
    
    let service = {}
    
    reqMethods.forEach((method) => {
      service[method] = function () {
        if (!client) throw new Error('apiClient not installed')
        return client[method].apply(null, arguments)
      }
    })
    
    export default service
    

    用途:

    import apiClient from '~/services/apiClient'
    
    export default {
      async current () {
        return apiClient.get('...')
      }
    }
    

    【讨论】:

    • 不幸的是,这对我不起作用。您提出的第一个解决方案不是有效的 javascript - 在 BookService.js 中显示 ; expectedDeclaration or statement expected。我根据您建议的原则进行了调整 - 通过操作方法将 axios 实例传递给服务,但它仍然无法运行我的请求。我已经更新了我的原始帖子,以显示我放置日志语句的位置以及控制台中返回的内容。
    • @Konzy262 修复了 BookService.js 中的错字(缺少括号)。你能分享一下这个问题的重现吗?
    【解决方案2】:

    在我的例子中,我按照我的 axios.js 中建议的文档导出了一个自定义的 axios 实例

    export default function ({ $axios }, inject) {
        const api = $axios.create({
            baseURL:'/api'
        })
        // Inject to context as $api
        inject('api', api)
      }
    

    然后在您的 getBook 服务中使用 this.$api.get 或 this.$api.post 以上对我有用

    【讨论】:

      【解决方案3】:

      看来你需要yarn add @nuxtjs/axiosnpm install @nuxtjs/axios 喜欢这里的设置指令才能工作:https://axios.nuxtjs.org/setup

      我还没有使用过 nuxt,但我认为通过在不实际安装的情况下将一些代码行添加到一些 js 文件中,不会使包在你的 repo 中可用。

      【讨论】:

      • 我已经安装了模块。 modules: ['@nuxtjs/axios'] 在我的nuxt.config.js
      • @Konzy262 你试过yarn add @nuxtjs/axiosnpm install @nuxtjs/axios 看看它是否有效吗?只需将您的工作存储库复制到另一个文件夹并尝试一下。
      猜你喜欢
      • 1970-01-01
      • 2021-12-15
      • 2021-09-19
      • 2019-10-17
      • 2021-12-06
      • 2021-05-19
      • 2021-07-01
      • 1970-01-01
      • 2019-05-26
      相关资源
      最近更新 更多