#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, а затем динамически импортировать этот компонент вместо этого.