【发布时间】: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