Резюме
В этой статье в основном рассказывается о том, как использоватьreact-app-rewired
расширятьcreate-react-app
Настроить поддержку многостраничных приложений, включая включениеPWA
, служба поддержкиant-design
Загрузка по требованию, совместимая с IE11.
- адрес проекта:GitHub.com/goblin-rab…
- демонстрационный адрес:goblin-laboratory.GitHub.IO/shame-multi-afraid…
Предварительный просмотр эффекта
инициализация
Создать проект
использоватьcreate-react-app
Создать проект
npx create-react-app .
create-react-app: Facebook.GitHub.IO/create-hot eat...
react-app-rewired
инициализация
- Установить
react-app-rewired
а такжеcustomize-cra
yarn add react-app-rewired customize-cra --dev
- Увеличивать
config-overrides.js
документ
// config-overrides.js
module.exports = function override(config, env) {
// do stuff with the webpack config...
return config;
};
- Изменить package.json
scripts
/* package.json */
"scripts": {
- "start": "react-scripts start",
+ "start": "react-app-rewired start",
- "build": "react-scripts build",
+ "build": "react-app-rewired build",
- "test": "react-scripts test",
+ "test": "react-app-rewired test",
"eject": "react-scripts eject"
},
react-app-rewired: GitHub.com/MentionMarney/Горячие…
ant-design
нагрузка по требованию
согласно сant-design
модификация документаconfig-overrides.js
/* config-overrides.js */
+ const { override, fixBabelImports, addLessLoader } = require('customize-cra');
- module.exports = function override(config, env) {
- // do stuff with the webpack config...
- return config;
- };
+ module.exports = {
+ webpack: override(
+ fixBabelImports('import', {
+ libraryName: 'antd',
+ libraryDirectory: 'es',
+ style: true,
+ }),
+ fixBabelImports('ant-design-pro', {
+ libraryName: 'ant-design-pro',
+ libraryDirectory: 'lib',
+ style: true,
+ camel2DashComponentName: false,
+ }),
+ addLessLoader({
+ javascriptEnabled: true,
+ localIdentName: '[local]--[hash:base64:5]',
+ // modifyVars: { '@primary-color': '#1DA57A' },
+ }),
+ ),
+ };
Справочная документация:Anta.design/docs/реагировать/…
Поддержка нескольких страниц
Изменить файл записи
- удалить по умолчанию
src/index.js
Входные файлы и связанные с ними зависимости - Создайте
src/pages/
содержание - Создайте
src/pages/index.js
а такжеsrc/pages/login.js
- Ссылаться на
dva
Инструкция по началу работызаписыватьsrc/pages/index.js
а такжеsrc/pages/login.js
Зависимый код - Многостраничные приложения должны использовать hashHistory, обратите внимание на модификацию
настроитьcreate-react-app
настроить
/* config-overrides.js */
+ const supportMultiPage = (config, env) => {
+ // do stuff with the webpack config...
+ return config;
+ };
module.exports = {
webpack: override(
+ supportMultiPage,
fixBabelImports('import', {
libraryName: 'antd',
libraryDirectory: 'es',
style: true,
}),
...
),
},
Изменить файл записи по умолчанию и корневой каталог
/* config-overrides.js */
const {
override,
fixBabelImports,
addLessLoader,
} = require('customize-cra');
+ const paths = require('react-scripts/config/paths');
+ paths.appIndexJs = `${paths.appSrc}/pages/index.js`;
+ paths.servedPath = './';
...
ИсправлятьHtmlWebpackPlugin
настроить
/* config-overrides.js */
...
+ const HtmlWebpackPlugin = require('html-webpack-plugin');
...
+ const getEntryConfig = env => {
+ const arr = 'development' === env ? [require.resolve('react-dev-utils/webpackHotDevClient')] : [];
+ return entry => {
+ return [...arr, `${paths.appSrc}/pages/${entry}.js`];
+ };
+ };
+
+ const removePlugin = (plugins, name) => {
+ const list = plugins.filter(it => !(it.constructor && it.constructor.name && name === it.constructor.name));
+ if (list.length === plugins.length) {
+ throw new Error(`Can not found plugin: ${name}.`);
+ }
+ return list;
+ };
+
+ const genHtmlWebpackPlugin = env => {
+ const minify = {
+ removeComments: true,
+ collapseWhitespace: true,
+ removeRedundantAttributes: true,
+ useShortDoctype: true,
+ removeEmptyAttributes: true,
+ removeStyleLinkTypeAttributes: true,
+ keepClosingSlash: true,
+ minifyJS: true,
+ minifyCSS: true,
+ minifyURLs: true,
+ };
+ const config = Object.assign(
+ {},
+ { inject: true, template: paths.appHtml },
+ 'development' !== env ? { minify } : undefined,
+ );
+ return entry => {
+ return new HtmlWebpackPlugin({
+ ...config,
+ chunks: ['vendors', `runtime~${entry}.html`, entry],
+ filename: `${entry}.html`,
+ });
+ };
+ };
+
+ const supportMultiPage = (config, env) => {
+ const list = ['index', 'login'];
+ config.entry = {};
+ config.plugins = removePlugin(config.plugins, 'HtmlWebpackPlugin');
+ const getEntry = getEntryConfig(env);
+ const getHtmlWebpackPlugin = genHtmlWebpackPlugin(env);
+ list.forEach(it => {
+ config.entry[it] = getEntry(it);
+ config.plugins.push(getHtmlWebpackPlugin(it));
+ });
+
+ if ('development' === env) {
+ config.output.filename = 'static/js/[name].bundle.js';
+ }
+ return config;
+ };
...
Измените devServer, среда разработки поддерживает несколько страниц
/* config-overrides.js */
...
module.exports = {
webpack: override(
...
),
+ devServer: configFunction => {
+ return (proxy, allowedHost) => {
+ const config = configFunction(proxy, allowedHost);
+ config.historyApiFallback.rewrites = [{ from: /^\/login\.html/, to: '/build/login.html' }];
+ return config;
+ };
+ },
};
Включить ПВА
Исправлятьcreate-react-app
По умолчаниюGenerateSW
настроить
/* config-overrides.js */
...
+ const WorkboxWebpackPlugin = require('workbox-webpack-plugin');
...
const supportMultiPage = (config, env) => {
...
if ('development' === env) {
config.output.filename = 'static/js/[name].bundle.js';
} else {
+ config.plugins = removePlugin(config.plugins, 'GenerateSW');
+ const workboxWebpackPlugin = new WorkboxWebpackPlugin.GenerateSW({
+ clientsClaim: true,
+ exclude: [/\.map$/, /asset-manifest\.json$/, /\.html$/],
+ importWorkboxFrom: 'local',
+ // navigateFallback: paths.servedPath + '/index.html',
+ // navigateFallbackBlacklist: [
+ // // Exclude URLs starting with /_, as they're likely an API call
+ // new RegExp('^/_'),
+ // // Exclude URLs containing a dot, as they're likely a resource in
+ // // public/ and not a SPA route
+ // new RegExp('/[^/]+\\.[^/]+$'),
+ // ],
+ });
+ config.plugins.push(workboxWebpackPlugin);
+ }
return config;
};
...
Зарегистрируйте serviceWorker в файле входа страницы
/* src/pages/index.js 和 src/pages/login.js 中同时修改 */
+ import * as serviceWorker from '../serviceWorker';
...
+ serviceWorker.register();
Совместимость с IE11
Увеличиватьreact-app-polyfill
полагаться
yarn add react-app-polyfill
Начальная позиция файла входа страницыimport
/* src/pages/index.js 和 src/pages/login.js 中同时修改 */
+ import 'react-app-polyfill/ie11';
+ import 'react-app-polyfill/stable';
Поддержка среды разработки
/* package.json */
"browserslist": {
"production": [
">0.2%",
"not dead",
"not op_mini all"
],
"development": [
"last 1 chrome version",
"last 1 firefox version",
- "last 1 safari version",
+ "last 1 safari version",
+ "last 1 ie version"
]
},
Напоминание об обновлении браузера до более ранней версии
- Измените файл index.html
+ <script>/*@cc_on window.location.href="http://support.dmeng.net/upgrade-your-browser.html?referrer="+encodeURIComponent(window.location.href); @*/</script>
<title>React App</title>
- Изменить параметры minifyJS
const genHtmlWebpackPlugin = env => {
const minify = {
removeComments: true,
collapseWhitespace: true,
removeRedundantAttributes: true,
useShortDoctype: true,
removeEmptyAttributes: true,
removeStyleLinkTypeAttributes: true,
keepClosingSlash: true,
- minifyJS: true,
+ minifyJS: {
+ comments: '@cc_on',
+ },
minifyCSS: true,
minifyURLs: true,
};
...
};