Динамический импорт SVG-файлов в NextJS

#reactjs #svg #webpack #import #next.js

Вопрос:

Я пытаюсь динамически импортировать файлы SVG, которые мы используем для повышения производительности. Прямо сейчас мы используем статический импорт, и из-за этого он добавляет все svg файлы в HTML-сборку, даже если нам нужно всего несколько файлов на страницу. Это увеличивает время загрузки страницы, так как HTML файл больше, и поэтому загрузка и чтение HTML файла занимает больше времени, чем необходимо.

При текущей настройке страница сначала загружается, но затем отображается пустой экран. Причина , по которой он это делает, заключается в том, что он сначала загружает во <span/> время загрузки, а затем заменяет его на svg , но так как импорт не проходит хорошо, он выходит из строя и вместо этого показывает пустой экран.

Проект представляет собой проект NextJS, работающий с Webpack. Это код, который я использую для импорта SVG файлов:

 export const Chevron = dynamic(
  () => import('./Icons/chevron.svg'), 
    {
      loading: () => <span/>,
      ssr: false,
    }
  )
 

Ниже вы найдете ошибку, которую я получаю. Обратите внимание на < перед и /> за ним, что, по-видимому, указывает на то, что он пытается проанализировать base64 строку до a JSX.Element .

 Warning: < /> is using incorrect casing. Use PascalCase for React components, or lowercase for HTML elements.
 

Вот моя следующая конфигурация:

   const withFonts = require('next-fonts');
  const withTM = require('next-transpile-modules');

  module.exports = withTM(
    withFonts({
      useFileSystemPublicRoutes: false,
      enableSvg: true,
      webpack(config) {
        config.module.rules.push({
          test: /.svg$/,
          use: [
            {
              loader: '@svgr/webpack',
              options: {
                svgoConfig: {
                  plugins: {
                    removeViewBox: false,
                  },
                },
              },
            },
          ],
        });

        return config;
      },
      assetPrefix: '/_react',
      transpileModules: [
        'swiper',
        'dom7',
        'query-string',
        'strict-uri-encode',
        'split-on-first',
        'set-harmonic-interval',
      ],
    }),
  );
 

Комментарии:

1. Почему бы просто не использовать его таким import foo from 'path/to/foo.svg'; import Image from 'next/image'; ... <Image src={foo} /> образом, Также, пожалуйста, добавьте в вопрос свой веб-пакет/следующую конфигурацию и версию. То, что вы испытываете, не является поведением по умолчанию.

2. @brc-dd Я отредактировал свой вопрос с ответами, которые вы просили

3. next/dynamic используется для импорта компонентов React, но вы пытаетесь импортировать SVG. Попробуйте создать компонент, который отображает SVG, а затем динамически импортировать этот компонент вместо этого.