Webpack генерирует неверный путь. Какой-то путь к пустому, так что он загружается только на стороне клиента response-loadable.json

Если я соберу все стили в один файл и разделю только javascript, он будет работать отлично. Эта проблема возникает только тогда, когда я пытаюсь разделить CSS.

Я установил ленивую загрузку для маршрутов и некоторых компонентов, которые требуют тяжелой библиотеки, такой как библиотека диаграмм.

Вот что я использую

css module
webpack ^4.26
MiniCssExtractPlugin ^0.4.4
Loadable.ReactLoadablePlugin ^5.5.0

Параметры загрузчика MiniCssExtractPlugin

module: {
    rules: [
      {
        test: /\.css$/,
        exclude: /react-flexbox-grid/,
        use: [
          MiniCssExtractPlugin.loader,
          {
            loader: 'css-loader',
            query: {
              modules: true,
              minimize: true,
              localIdentName: '[hash:base64:5]'
            }
          },
          {
            loader: 'postcss-loader',
            options: {
              plugins: (loader) => [
                require('postcss-modules-values')(),
                require('postcss-nested')(),
                require('autoprefixer')(),
              ]
            }
          },

        ]
      }
      //
    ]
  },

Когда я запускаю веб-пакет, он генерирует

"undefined": [
    {
      "id": "",
      "name": null,
      "file": "Building~Search.css?v=05a4504a93bc",
      "publicPath": "/dist/Building~Search.css?v=05a4504a93bc"
    },
    {
      "id": "",
      "name": null,
      "file": "Building~Search.css?v=05a4504a93bc",
      "publicPath": "/dist/Building~Search.css?v=05a4504a93bc"
    },

Параметры SplitChunks Как я уже упоминал ранее, если я объединю все стили, все будет работать нормально, в React-loadable.json нет нулевых или неопределенных значений.

 optimization: {
    splitChunks: {
      maxAsyncRequests: 20,
      maxInitialRequests: 20,
      minChunks: 2,
      chunks: 'all',
 // cacheGroups: {
      //   styles: {
      //     name: 'styles',
      //     test: /\.css$/,
      //     chunks: 'all',
      //     enforce: true
      //   },
      // }

    },
  },

сср рендеринг

let modules = []
      const context = {}
      const htmlRoot = (
        <Provider store={store}>
          <StaticRouter location={urlPath} context={context}>
            <AppRoot />
          </StaticRouter>
        </Provider>
      )

      store
        .runSaga(rootSaga)
        .done.then(() => {
          const storeState = store.getState()

          const sagaLookups = storeState.lookups

            const RTS = renderToString(
              <Provider store={store}>
                <StaticRouter location={urlPath} context={context}>
                  <Loadable.Capture report={moduleName => {modules.push(moduleName)}}>
                    <AppRoot />
                  </Loadable.Capture>
                </StaticRouter>
              </Provider>,
            )
            const head = Helmet.renderStatic() 

            res.status(code).send(renderDom(RTS, port, host, storeState, head, getBundles(stats, modules)))
          }
        })
        .catch(e => {
          console.log(e.message)
          res.status(500).send(e.message)
        })

      renderToString(htmlRoot)
      store.close()

0 ответов

Другие вопросы по тегам