1

我正在尝试在一个地方使用 axios 和 axios-mock-adapter 来聚合更多模拟,然后导出 axios 实例以在我想要的任何地方使用它:

模拟.js

import axios from 'axios';
import MockAdapter from 'axios-mock-adapter';

let instance = axios.create({
    baseURL: 'https://some-domain.com/api/',
    timeout: 1000,
    headers: {'X-Custom-Header': 'foobar'}
});

let mock = new MockAdapter(instance);
mock.onGet('/users').reply(200, {
    users: [
        { id: 1, name: 'John Smith' }
    ]
});

export {instance}

main.js

import instance from './mock'

instance.get('/users')
  .then(function(response) {
    console.log(response.data);
});

但我得到这个错误:

Uncaught TypeError: Cannot read property 'get' of undefined

谁能帮我?我错过了什么?

4

2 回答 2

4

使用export default instance代替export {instance}

于 2018-01-03T18:39:15.867 回答
1

main.js

import {instance} from './mock'

避免默认导出- 它允许以任何名称导入导出的模块。

最好使用命名导出(包装在 {} 中)在所有导入中强制执行一致的命名。

于 2019-02-06T00:18:11.353 回答