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
屬性值的時候要單獨給里面的值再加一個引號,否則輸出的值不是字符串,所以會報錯。



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM