我想在我的应用程序中使用SVG作为React组件.

我遵循了在webpack中添加svgr的步骤.svgr documents svgr-doc中的配置文件,但控制台开发工具中有一个错误:

react-dom.development.js:67 Warning: < /> is using incorrect casing. Use PascalCase for React components, or lowercase for HTML elements.

SVG没有显示.

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"
  ]
}

推荐答案

从webpack rules的配置来看,您似乎与type: "asset/inline"的上一条规则发生了名称冲突,type: "asset/inline"也根据您的test case 处理svg.

要解决这个问题,您可以删除最后一条规则中的svg,使其成为

test: /\.(woff(2)?|eot|ttf|otf|)$/,

或者,您可以将webpack配置为使用这两个规则,并附加一个约束条件,如前所述.如果您在应用程序的其他位置需要文件内容,建议您这样做.为此,请添加

resourceQuery: /url/, // *.svg?url

最后一条规则

resourceQuery: { not: [/url/] }, // exclude react component if *.svg?url

遵守你的@svgr/webpack规则.

Javascript相关问答推荐

JavaScript setSYS()是否有可能更早触发?

我的YouTube视频没有以html形式显示,以获取免费加密信号

reaction useEffect KeyDown for each 条目配音输出

如何解决这个未能在响应上执行json:body stream已读问题?

D3多线图显示1线而不是3线

我试图实现用户验证的reduxstore 和操作中出了什么问题?

未捕获错误:在注销后重定向到/login页面时找不到匹配的路由

为什么ngModel不能在最后一个版本的Angular 17上工作?'

Angular 17—每当一个布尔变量变为真时触发循环轮询,只要它保持为真

在Vite React库中添加子模块路径

MathJax可以导入本地HTML文档使用的JS文件吗?

阿波罗返回的数据错误,但在网络判断器中是正确的

无法检测卡片重叠状态的问题

如何在Vue 3中创建自定义 Select 组件,并将选项作为HTML而不是props 传递?

如果Arrow函数返回函数,而不是为useEffect返回NULL,则会出现错误

如何将多维数组插入到另一个多维数组中?

与svg相反;S getPointAtLength(D)-我想要getLengthAtPoint(x,y)

是否可以将Select()和Sample()与Mongoose结合使用?

如何使用画布在另一个内部绘制一个较小但相同的形状,同时保持恒定的边界厚度?

Node.js错误: node 不可单击或不是元素