博客
关于我
create-react-app build 打包隐藏源码
阅读量:160 次
发布时间:2019-02-28

本文共 1003 字,大约阅读时间需要 3 分钟。

在使用create-react-app时,打包生产环境npm run build,浏览器打开后仍然是可以看到源码的。

在这里以新建一个默认项目为例:

 

App.js

解决办法一:

项目根目录新建.env文件,内容如下:

 

GENERATE_SOURCEMAP=false

package.json:

"scripts": {    "start": "dotenv -e .env.frm react-app-rewired start",    "start:pro": "dotenv -e .env.frm -e .env.pro react-app-rewired start",    "build": "dotenv -e .env.frm -e .env react-app-rewired build",    "build:pro": "dotenv -e .env.pro -e .env.frm react-app-rewired build",    "test": "react-app-rewired test --env=jsdom",    "eject": "react-scripts eject"  },

(build中引入.env文件,多个env文件用 -e 隔开),需要下载dotenv-cli

yarn add dotenv-cli

然后重新打包,浏览器打开后就看不到源码啦。

解决方法二:

原理

为了探究原理,执行eject后,可以看到webpack配置中有这么一段

// Source maps are resource heavy and can cause out of memory issue for large source files.const shouldUseSourceMap = process.env.GENERATE_SOURCEMAP !== 'false';

这里的process.env.GENERATE_SOURCEMAP控制着是否捎带源码。所以我们可以配置环境变量GENERATE_SOURCEMAP=false即可。

当执行build时,将按顺序优先寻找.env.production.local, .env.production, .env.local, .env文件来配置环境变量,所以就有了上面的操作。

结果如下:

=

转载地址:http://cead.baihongyu.com/

你可能感兴趣的文章
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>
NIO_通道之间传输数据
查看>>
NIO三大组件基础知识
查看>>
NIO与零拷贝和AIO
查看>>
NIO同步网络编程
查看>>
NIO基于UDP协议的网络编程
查看>>
NIO笔记---上
查看>>
NIO蔚来 面试——IP地址你了解多少?
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
NISP国家信息安全水平考试,收藏这一篇就够了
查看>>
NIS服务器的配置过程
查看>>
NIS认证管理域中的用户
查看>>
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>
NiuShop开源商城系统 SQL注入漏洞复现
查看>>
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLog类库使用探索——详解配置
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 模型中的偏差和公平性检测
查看>>