导入SVG作为WebPack 5的React组件
我想将SVG用作我的应用程序中的React组件。 我正在使用:react 17.0.2,webpack 5.57.1, @svgr/webpack 6.2.1。
我遵循svgr文档中添加svgr的步骤 svgr-doc 但是控制台开发工具中存在错误:
react-dom.development.js:67 Warning: < /> is using incorrect casing. Use PascalCase for React components, or lowercase for HTML elements.
SVG没有显示。 我无法将其作为React组件导入。
我的应用程序:
import React from 'react';
import ReactDOM from 'react-dom';
import CalendarIcon from './Calendar.svg'
const App = () => (
<div>
Test
<CalendarIcon/>
</div>
);
ReactDOM.render(<App />, document.getElementById('app'));
webpack文件:
const path = require('path');
const HtmlWebPackPlugin = require('html-webpack-plugin');
const ModuleFederationPlugin = require('webpack/lib/container/ModuleFederationPlugin');
const deps = require('./package.json').dependencies;
module.exports = {
output: {
filename: '[name].[contenthash:20].esm.js',
chunkFilename: '[name].[chunkhash:20].esm.js',
hashFunction: 'xxhash64',
pathinfo: false,
crossOriginLoading: false,
clean: true,
publicPath: 'auto',
},
resolve: {
extensions: ['.tsx', '.ts', '.jsx', '.js', '.json'],
},
devServer: {
port: 3011,
historyApiFallback: true,
},
module: {
rules: [
{
test: /\.m?js/,
type: 'javascript/auto',
resolve: {
fullySpecified: false,
},
},
{
test: /\.(css|s[ac]ss)$/i,
use: ['style-loader', 'css-loader', 'postcss-loader'],
},
{
test: /\.(ts|tsx|js|jsx)$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
},
},
{
test: /\.svg$/i,
issuer: /\.[jt]sx?$/,
use: ['@svgr/webpack'],
},
{
test: /\.(?:ico|gif|png|jpg|jpeg)$/i,
type: 'asset/resource',
},
{
test: /\.(woff(2)?|eot|ttf|otf|svg|)$/,
type: 'asset/inline',
},
],
},
plugins: [
new ModuleFederationPlugin({
name: 'sidebar',
filename: 'remoteEntry.js',
remotes: {},
exposes: {
'./SideBar': './src/components/Sidebar/index.tsx',
},
shared: {
...deps,
react: {
singleton: true,
requiredVersion: deps.react,
},
'react-dom': {
singleton: true,
requiredVersion: deps['react-dom'],
},
},
}),
new HtmlWebPackPlugin({
template: './src/index.html',
}),
],
};
babelrc文件:
{
"presets": ["@babel/preset-typescript", "@babel/preset-react", "@babel/preset-env"],
"plugins": [
["@babel/transform-runtime"],
"babel-plugin-styled-components"
]
}
I want to use SVG as a React Component in my app.
I'm using: react 17.0.2, Webpack 5.57.1, @svgr/webpack 6.2.1.
I followed the steps on adding svgr in webpack.config file as in svgr documents svgr-doc but there is an Error in the console dev tools:
react-dom.development.js:67 Warning: < /> is using incorrect casing. Use PascalCase for React components, or lowercase for HTML elements.
and the SVG doesn't show.
I can't import it as a React Component.
my App:
import React from 'react';
import ReactDOM from 'react-dom';
import CalendarIcon from './Calendar.svg'
const App = () => (
<div>
Test
<CalendarIcon/>
</div>
);
ReactDOM.render(<App />, document.getElementById('app'));
webpack file:
const path = require('path');
const HtmlWebPackPlugin = require('html-webpack-plugin');
const ModuleFederationPlugin = require('webpack/lib/container/ModuleFederationPlugin');
const deps = require('./package.json').dependencies;
module.exports = {
output: {
filename: '[name].[contenthash:20].esm.js',
chunkFilename: '[name].[chunkhash:20].esm.js',
hashFunction: 'xxhash64',
pathinfo: false,
crossOriginLoading: false,
clean: true,
publicPath: 'auto',
},
resolve: {
extensions: ['.tsx', '.ts', '.jsx', '.js', '.json'],
},
devServer: {
port: 3011,
historyApiFallback: true,
},
module: {
rules: [
{
test: /\.m?js/,
type: 'javascript/auto',
resolve: {
fullySpecified: false,
},
},
{
test: /\.(css|s[ac]ss)$/i,
use: ['style-loader', 'css-loader', 'postcss-loader'],
},
{
test: /\.(ts|tsx|js|jsx)$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
},
},
{
test: /\.svg$/i,
issuer: /\.[jt]sx?$/,
use: ['@svgr/webpack'],
},
{
test: /\.(?:ico|gif|png|jpg|jpeg)$/i,
type: 'asset/resource',
},
{
test: /\.(woff(2)?|eot|ttf|otf|svg|)$/,
type: 'asset/inline',
},
],
},
plugins: [
new ModuleFederationPlugin({
name: 'sidebar',
filename: 'remoteEntry.js',
remotes: {},
exposes: {
'./SideBar': './src/components/Sidebar/index.tsx',
},
shared: {
...deps,
react: {
singleton: true,
requiredVersion: deps.react,
},
'react-dom': {
singleton: true,
requiredVersion: deps['react-dom'],
},
},
}),
new HtmlWebPackPlugin({
template: './src/index.html',
}),
],
};
babelrc file:
{
"presets": ["@babel/preset-typescript", "@babel/preset-react", "@babel/preset-env"],
"plugins": [
["@babel/transform-runtime"],
"babel-plugin-styled-components"
]
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
从您的webpack
规则>配置中,您看起来与
类型的最后一个规则相冲突,
类型:“ Asset/inline”
,它也在处理SVG到您的测试
案例。要解决此问题,您可以在最后一个规则中删除
svg
,以便它变为或可以配置WebPack以使用带有附加约束的两个规则,如所述在svgr docs中。如果您需要的话,建议这样做在您的应用程序中的其他一点上文件内容。为此,将
最后一个规则
添加到您的
@svgr/webpack
规则。From your webpack
rules
configuration, it looks like you’re having a name clash with the last rule withtype: "asset/inline"
, which is handling svg as well according to yourtest
case.To fix this, you can either remove
svg
in the last rule so that it becomesor you can configure webpack to use both rules with an additional constraint, as described in the SVGR docs. This is recommended if you need the file contents at some other point in your application. For this, add
To the last rule and
To your
@svgr/webpack
rule.