CDN网络分发服务 请求资源时最近的服务器将缓存内容交给用户
体积较大且变动不多的文件存在CDN文件中 react react-dom资源

const path = require('path')
const { whenProd, getPlugin, pluginByName } = require('@craco/craco')module.exports = {webpack: {alias: {'@': path.resolve(__dirname, 'src')},configure: (webpackConfig) => {let cdn = {js:[]}whenProd(() => {webpackConfig.externals = {react: 'React','react-dom': 'ReactDOM'}cdn = {js: ['https://cdnjs.cloudflare.com/ajax/libs/react/18.1.0/umd/react.production.min.js','https://cdnjs.cloudflare.com/ajax/libs/react-dom/18.1.0/umd/react-dom.production.min.js',]}})const { isFound, match } = getPlugin(webpackConfig,pluginByName('HtmlWebpackPlugin'))if (isFound) {match.userOptions.files = cdn}return webpackConfig}}
}
index.js中
<body><div id="root"></div><!-- 加载第三发包的 CDN 链接 --><% htmlWebpackPlugin.options.files.js.forEach(cdnURL => { %><script src="<%= cdnURL %>"></script><% }) %>
</body>