zoukankan      html  css  js  c++  java
  • vue-cli生成的项目配置开发和生产环境不同的接口

    vue-cli生成的项目,vue项目配置了不同开发环境的接口地址,axios.defaults.baseURL如何引用这个地址,这是在我发布项目的时候考虑的,于是想到了

    方法一:

    config下配置文件分别如下:

    dev.env.js:
    
    'use strict'
    const merge = require('webpack-merge')
    const prodEnv = require('./prod.env')
    
    module.exports = merge(prodEnv, {
      NODE_ENV: '"development"',
      API_ROOT: '"//xxx.xxx.xxx.xxx:9001"'
    })
    prod.env.js
    
    'use strict'
    module.exports = {
      NODE_ENV: '"production"',
      API_ROOT: '"https://xxx.zzz.com"'
    }

    我在app.vue和main.js中试了以下方法,可以生效,但是因为在配置API_ROOT的时候里面地址带双引号,所以不能直接使用该接口地址,如果去掉API_ROOT中的双引号,打包的时候又会报错。

    const config = require('../config')
    import axios from 'axios';
    if (process.env.NODE_ENV === 'development') {
      axios.defaults.baseURL = config.dev.env.API_ROOT;
    } else {
      axios.defaults.baseURL = config.build.env.API_ROOT;
    }

    所以暂时没想到该怎么解决这个问题…………遂放弃方法一。

    方法二:(集热心网友提供的方案)

    一般项目webpack会有两个或多个配置文件,如:
    webpack.prod.conf.js  对应线上打包
    webpack.dev.conf.js   对应开发环境


    使用webpack.DefinePlugin就可以

    开发环境(webpack.dev.conf.js):
    
    //开发环境下的baseURL
    new webpack.DefinePlugin({
      BASE_URL:"'xxxxxxxxx'"
    })
    线上环境(webpack.prod.conf.js):
    
     //线上环境下的baseURL
    new webpack.DefinePlugin({
      BASE_URL:"'xxxxxxxxx'"
    })

    我们只需要在入口文件中写上:axios.defaults.baseURL = BASE_URL;即可。

    通过配置了DefinePlugin,那么这里面的标识就相当于全局变量,你的业务代码可以直接使用配置的标识。

    注意:这里配置

    BASE_URL
    属性值的时候要单独给里面的值再加一个引号,否则输出的值不是字符串,所以会报错。


  • 相关阅读:
    SQL2014还原到2008
    SQL SERVER2014 安装 Error code 0x858C001B.
    c++builder XE7 C++11 C++0x 新语法
    c++Builder XE6 MD5 加密算法 BASE64 URL 编码
    手机新功能
    xe fmx 怎么改变button颜色
    XE6 任务栏 控件
    js里面return 和 return false的区别
    web.xml的contextConfigLocation作用及自动加载applicationContext.xml
    mybatis-config.xml配置
  • 原文地址:https://www.cnblogs.com/beileixinqing/p/7724779.html
Copyright © 2011-2022 走看看