vue跨域请求配置

npm安装

$ npm install axios --save

新建vue.config.js

module.exports = {
    baseUrl: './',
    assetsDir: 'static',
    productionSourceMap: false,

    devServer: {

        proxy: {
            '/api': {
                target: 'http://127.0.0.1:8080',
                changeOrigin: true,
                pathRewrite: {
                   
                    '^/api': ''
                }
            }
        }
    }
}

main.js 使用axios


import axios from 'axios'
import VueAxios from 'vue-axios'
import VueRouter from 'vue-router'
import vueConfig from '../vue.config';
import qs from 'qs'
Vue.use(VueRouter);

Vue.use(VueAxios,axios);
Vue.use(ElementUI, {
    size: 'small'
});
Vue.prototype.$axios = axios
axios.defaults.baseURL = '/api'  //关键代码

vue.config.js

module.exports = {
    baseUrl: './',
    assetsDir: 'static',
    productionSourceMap: false,

    devServer: {

        proxy: {
            '/api': {
                target: 'http://127.0.0.1:8080',
                changeOrigin: true,
                pathRewrite: {
                   
                    '^/api': ''
                }
            }
        }
    }
}
import axios from 'axios';

const service = axios.create({
    // process.env.NODE_ENV === 'development' 来判断是否开发环境
    // easy-mock服务挂了,暂时不使用了
    baseURL: '/api',
    timeout: 5000
});

src目录下新建request.js

import axios from 'axios';

const service = axios.create({
    // process.env.NODE_ENV === 'development' 来判断是否开发环境
    // easy-mock服务挂了,暂时不使用了
    baseURL: '/api',
    timeout: 5000
});

service.interceptors.request.use(
    config => {
        return config;
    },
    error => {
        console.log(error);
        return Promise.reject();
    }
);

service.interceptors.response.use(
    response => {
        if (response.status === 200) {
            return response.data;
        } else {
            Promise.reject();
        }
    },
    error => {
        console.log(error);
        return Promise.reject();
    }
);

export default service;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值