每次运行gulp设置环境变量时,我都不希望输入额外的参数NODE_ENV='production' gulp
。
我宁愿通过任务从gulp中设置环境变量。
实现这一目标的好方法是什么?
gulp.task('set-dev-node-env', function() {
return process.env.NODE_ENV = 'development';
});
gulp.task('set-prod-node-env', function() {
return process.env.NODE_ENV = 'production';
});
使用它像:
gulp.task('build_for_prod', ['set-prod-node-env'], function() {
// maybe here manipulate config object
config.paths.src.scripts = config.paths.deploy.scripts;
runSequence(
'build',
's3'
);
});
试试gulp-env
有关如何在运行nodemon任务之前设置一些环境变量的快速示例:
// gulpfile.js
var gulp = require('gulp');
var nodemon = require('nodemon');
var env = require('gulp-env');
gulp.task('nodemon', function() {
// nodemon server (just an example task)
});
gulp.task('set-env', function () {
env({
vars: {
MONGO_URI: "mongodb://localhost:27017/testdb-for-british-eyes-only",
PORT: 9001
}
})
});
gulp.task('default', ['set-env', 'nodemon'])
您也可以在package.json
中将其定义为脚本
{
"name": "myapp",
"scripts": {
"gulp": "NODE_ENV='development' gulp",
"gulp-build": "NODE_ENV='production' gulp"
},
...
}
然后用npm run gulp-build
运行它。这有一些好处
您也可以默认设置一个,并从json
文件中读取变量:
gulp.task('set-env', function () {
var envId = gutil.env.env;
if (!envId) {
envId = "dev";
}
genv({
file: "env." + envId + ".json"
});
});
默认情况下,这将始终是dev
env,你可以调用它设置另一个env,如下所示:
gulp --env prod
更多gulp-env
您可以按如下方式设置环境:
// Environment Setup
var env = process.env.NODE_ENV || 'development';
然后,您可以使用该环境来处理代码,如下所示:
gulp.task('js',function(){
gulp.src(jsPath)
.pipe(browserify({debug: env === 'development'}))
.pipe(gulpif(env === 'production' , uglify()))
.pipe(gulp.dest(jsDest));
});