VueCli2,前后端分离时,前端开发如何访问后端的API接口

VueCli2,前后端分离时,前端开发如何访问后端的API接口

前端开发:
  1. VueCli2项目结构
    在这里插入图片描述

    配置Config下的index.js,配置后就可以跨域访问后台api了

    dev: {
    // Paths
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    proxyTable: {
    // 在访问后台数据时,在地址前面面加上/apis,则请求会重写为 http://127.0.0.1:3000,
    //下面的pathRewrite指 /apis 会被重写为 '',这里用的正则表达式 '^'表示从头开始匹配
      '/apis/': {
        target: "http://127.0.0.1:3000",
        changeOrigin: true,
        pathRewrite: {
          '^/apis': ''
        }
      }
    }
    
  2. 开发环境 与 生产环境

在开发时,需要跨域访问后台的接口,但是开发完上线时,则不需要,于是可以配置Config下的dev.env和prod.env

  • dev.env.js 配置
    module.exports = merge(prodEnv, {
    NODE_ENV: '"development"',
    APIS_HOST: '"/apis'
    })
    
  • prod.env.js 配置
    module.exports = {
    NODE_ENV: '"production"',
    APIS_HOST: '""'
    }
    
  • 跨域时: 这里使用的axios跨域
    • 配置axios npm install --save axios npm install --save vue-axios
      import Vue from 'vue'
      import axios from 'axios'
      import VueAxios from 'vue-axios'
      Vue.use(VueAxios, axios)
      
    • 完成跨域
      function verifyCodeReq() {
       return new Promise((resolve, reject) => {
      	Vue.axios
      		.get(process.env.APIS_HOST + "/member/verifyCode", {
      			params: {}
      		})
      		.then(res => {
      		 	resolve(typeof(res));
      		})
      		.catch(err => {
      	 		reject(err);
      		 })
      	})
      }
      
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值