@material-design-icons/svg
をインポートして使うぞ!
と張り切って導入したらめっちゃ怒られたので鎮める方法を残します。
どんなエラーだったのか?
まず@material-design-icons/svg
をinstallします。
npm install --save-dev @material-design-icons/svg
yarn add -D @material-design-icons/svg
pnpm add -D @material-design-icons/svg
インストールされたらコンポーネントで下記のように記述し読み込みました。
import ChevronRight from '@material-design-icons/svg/filled/chevron_right.svg?react'
そして下記のエラーが発生しました。
InvalidCharacterError: Failed to execute 'createElement' on 'Document': The tag name provided ('') is not a valid name.
無効なタグ名を使って要素を作成しようとしたときに発生するようです…
解決方法
認識されるように設定してあげます。
viteでbuildされている場合は、vite-plugin-svgr
を利用することで修正できました。
ツールによってインストールするものが異なります。
使っているbuildツールと共にsvgr
をキーワードに含めて検索すると良いと思います!
npm install --save-dev vite-plugin-svgr
yarn add -D vite-plugin-svgr
pnpm add -D vite-plugin-svgr
npmのサイトを確認しながら設定していきます。
import svgr from "vite-plugin-svgr";
export default defineConfig({
plugins: [svgrPlugin()],
.
.
.
})
おおよそ完了ですが、TypeScriptの環境だとSVGの読み込み位置で下記のようなエラーが出ると思います。
モジュール '@material-design-icons/svg/filled/chevron_right.svg?react' またはそれに対応する型宣言が見つかりません。
これだけではエラーを解消することができません。
ts.config
の設定ファイルを編集する必要があります。
vite-plugin-svgr
のプラグインにはsvgの型定義が書かれていますが、うまく読み込めていないことが発生していました…
vite-plugin-svgr
のプラグインには下記のようにsvgの型定義がされています。
declare module "*.svg?react" {
import * as React from "react";
const ReactComponent: React.FunctionComponent<
React.ComponentProps<"svg"> & { title?: string }
>;
export default ReactComponent;
}
プラグインに定義してある型定義を利用できるようにts.config
に設定を追記します。
"compilerOptions": {
"types": ["vite-plugin-svgr/client"]
},
コンポーネントとして呼び出して確認してみてください!
<ChevronRight>
画像の名称は下記のサイトから確認できます。
まとめ
知識が足りず間違ったものをインストールしたり、誤った書き方をしてしまったりで解消に時間がかかってしまいました…。
終わってみればなんのこともないのですが、この解決方法が良いのかはまだわかっておりません。
Reactを利用しているプロジェクトでSVGアイコンを扱いたい時には注意してください!
参考URL