gpt4 book ai didi

javascript - React 和 Grunt - Envify NODE_ENV ='production' 和 UglifyJS

转载 作者:数据小太阳 更新时间:2023-10-29 03:59:22 38 4
gpt4 key购买 nike

我正在使用 Grunt 来构建一个 React 项目,我想要“开发”和“生产”风格。正如 React 文档所说:

To use React in production mode, set the environment variable NODE_ENV to production. A minifier that performs dead-code elimination such as UglifyJS is recommended to completely remove the extra code present in development mode.

我对使用 grunt、browserify 和其他东西非常陌生,但让我们看看。我遇到的第一个问题是 envify,我将它用作转换:

browserify: {
options: {
transform: ['reactify'],
extensions: ['.jsx']
},
dev:{
options: {
watch: true //Uses watchify (faster)
},
src: ['js/app.js'],
dest: 'js/bundle.js'
},
/**
* To use React in production mode, set the environment variable NODE_ENV to production.
* A minifier that performs dead-code elimination such as UglifyJS is
* recommended to completely remove the extra code present in development mode.
**/
prod: {
options: {
transform: ['envify'] //How to set up NOD_ENV='production' ?
},
src: ['js/app.js'],
dest: 'js/bundle.js'
}
},

好的,执行 grunt:dev 工作得很好。所以当运行 grunt:prod 时...我如何设置 NODE_ENV: 'production'?我的意思是,我知道我正在将“envify”作为转换传递,但是...不知道如何使用它。

在此之后,我还有一个丑化任务:

uglify: {
prod: {
files: {
'js/bundle.min.js': ['js/bundle.js']
}
}
}

所以在调用 grunt:prod 之后,它创建的是两个文件(bundle.jsbundle-min.js)。在生产中,我希望只有 bundle.min.js。我知道我能做到:

js/bundle.js': ['js/bundle.js']

但是嗯,我不知道是否有办法将它重命名为 bundle.min.js,我想是这样...问题是我在 html 中有:

<script src="js/bundle.js"></script>

这里是否还有一个技巧可以让它接受 bundle.js 或 bundle.min.js?

提前致谢。

最佳答案

转换是本地的,制作精良的包将它们的转换放在它们的 package.json 文件中。除非您在您自己的代码中使用 envify,否则您不需要对它做任何事情。

您需要的是 grunt-env ,或另一种设置环境变量的方法。

这是使用 package.json 的替代方法:

{
"scripts": {
"build": "NODE_ENV=development grunt build-dev",
"dist": "NODE_ENV=production grunt dist"
}
},
"devDependencies": {
"grunt": "...",
"grunt-cli": "..."
}

这里的好处是使用你的包的人甚至不需要全局安装 grunt。 npm run build 将使用正确的环境变量集运行 ./node_modules/.bin/grunt build-dev

关于javascript - React 和 Grunt - Envify NODE_ENV ='production' 和 UglifyJS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25751045/

38 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com