webpack开发模式和生产模式设置及不同环境脚本执行
1. webpack设置开发模式和生产模式
(1). DefinePlugin插件设置
new webpack.DefinePlugin({ 'process.env': { NODE_ENV: '"production"' }, __DEV__: false }) new webpack.DefinePlugin({ 'process.env': { NODE_ENV: JSON.stringify('production') }, __DEV__: false }) new webpack.DefinePlugin({ 'process.env.NODE_ENV': '"production"', __DEV__: false })
(2). 命令行设置
"scripts": { "watch": "cross-env NODE_ENV=production ....." }
2. 开发模式和生产模式脚本区分执行
if(process.env.NODE_ENV == 'development'){ console.log('development'); } else{ console.log('production'); } if(__DEV__){ console.log('development'); } else{ console.log('production'); }
以上代码不必担心在浏览器中会不兼容,webpack会将其编译为一个bool值:
if(true){ console.log('development'); } else{ console.log('production'); } if(false){ console.log('development'); } else{ console.log('production'); }
如果使用了UglifyJsPlugin,则会编译为:
console.log('development');
console.log('production');
完全不会增加多余的代码,不会增大线上文件体积,所以可以放心使用。
3. html页面注入环境变量
在htmlWebpackPlugin中添加环境变量env的配置
new HtmlWebpackPlugin({ template: './src/public/index.ejs', inject: 'body', hash: true, env: process.env.NODE_ENV })
在html页面中可以这样使用
<% if(htmlWebpackPlugin.options.env == 'production'){ %> <script src="xxx/react.min.js"></script> <script src="xxx/react-dom.min.js"></script> <% } else { %> <script src="xxx/react.development.js"></script> <script src="xxx/react-dom.development.js"></script> <% } %>
通常情况下,开发模式hash为false,生成模式hash为true,也可以用hash这个变量来区分环境
<% if(htmlWebpackPlugin.options.hash){ %> <script src="xxx/react.min.js"></script> <script src="xxx/react-dom.min.js"></script> <% } else { %> <script src="xxx/react.development.js"></script> <script src="xxx/react-dom.development.js"></script> <% } %>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具