把 inProd 定义在每个需要的文件的内部,而不是进行全局定义。

This commit is contained in:
陆柯 2022-09-19 12:04:43 +08:00
parent 2a94d1e64d
commit 1c65b96539

View File

@ -2,15 +2,6 @@ const fs = require('fs')
const path = require('path')
const deepmerge = require('deepmerge')
// process.env.NODE_ENV 不是天然就有的,而是由 cross-env 或 vue/uniapp 配置的。
// 如果通过 vscode 的 launch.json 直接启动,就不存在 process.env.NODE_ENV。在 launch.json 时显然是开发环境。
// 在 Express 里: server = require('express')(); server.get('env') === server.settings.env === process.env.NODE_ENV
// 在 uniapp 里,在 main.js/App.vue 里都可以访问 process.env.NODE_ENV。在 页面.vue 的代码区域,可以访问,但在模版区域,不能访问。在浏览器中时,不能访问。
// 在 uniCloud 里,存在 process.env但不存在 process.env.NODE_ENV。
// 如果在不能访问 process.env.NODE_ENV 的地方也需要该信息,可添加 wo.envar.prodev = process.env.NODE_ENV || 'development'
process.env.NODE_ENV = process.env.NODE_ENV || typeof uniCloud === undefined ? 'production' : 'development'
globalThis.inProd = process.env.NODE_ENV === 'production' // 提供一个全局的简化环境变量,方便从任何地方引用. // 用 production 测试,防止 NODE_ENV 未定义.
module.exports = {
/** envar files commander parameters
* @param envarFiles:
@ -32,7 +23,7 @@ module.exports = {
if (!global.envar) {
global.envar = rawEnvar // 不知为何必须定义成全局变量才能保证多次require只执行一次。
console.info(`<<<<<<<< Configuring [${process.env.NODE_ENV || 'development'}] Environment <<<<<<<<`)
console.info(`<<<<<<<< Configuring [${process.env.NODE_ENV}] Environment <<<<<<<<`)
console.info('- Loading Configuration Files (读取配置文件)')
if (typeof envarFiles === 'string') {
@ -83,7 +74,7 @@ module.exports = {
console.error(' - commander not available!')
}
console.log(`>>>>>>>> Configured [${process.env.NODE_ENV || 'development'}] Variables >>>>>>>>`)
console.log(`>>>>>>>> Configured [${process.env.NODE_ENV}] Environment >>>>>>>>`)
}
return global.envar