react?+?vite?+?ts項目中優(yōu)雅使用.svg文件
在react + vite + ts項目中svg文件的基本使用
1、直接在JSX組件中引入SVG文件
使用img標簽,img標簽的src代碼嵌入到JSX組件中,例如:
// XXcomponent.tsx
import help_icon from '@/icon/help_icon.svg';
function MySVGComponent() {
return (
<img src={help_icon} alt="" />
);
}
export default MySVGComponent;1這種使用方法有很多重復的代碼,而且不好維護,我們希望至少能夠重復使用引用一次的svg文件,將svg資源封裝成組件,方法見2。
2、安裝vite-plugin-svgr插件
修改配置,將SVG文件作為React組件導入
2.1 安裝vite-plugin-svgr
npm i vite-plugin-svgr -D
2.2 在vite配置文件中注冊已安裝的vite-plugin-svgr插件
// vite.config.ts
import { defineConfig } from "vite";
import react from "@vitejs/plugin-react";
import svgr from "vite-plugin-svgr";
export default defineConfig({
plugins: [react(), svgr()]
});2.3 配置ts.config.json
// ts.config.json 添加"types": ["vite-plugin-svgr/client"] 這項配置
{
"compilerOptions": {
"types": ["vite-plugin-svgr/client"]
}
}2.4 使用
// XXcomponent.tsx
import { ReactComponent as HelpIcon } from '@/icon/help_icon.svg';
function MySVGComponent() {
return (
<HelpIcon />
);
}
export default MySVGComponent;
3、節(jié)省引入"path/to/icon_xx.svg"
在2的基礎上進行封裝,節(jié)省引入"path/to/icon_xx.svg"的步驟。
思路是將所有的icon_xx.svg放在src/icon 目錄下
封裝一個<SvgIcon /> 組件 <SvgIcon />的Props中iconName對應icon_xx.svg的名稱。
import(@/icon/${iconName}.svg)在需要使用svg的地方引入<SvgIcon />組件。
這種思路有點類似于vue2中的svg-sprite-loader,只是沒有注冊在全局。
以上就是react + vite + ts項目中優(yōu)雅使用.svg文件的詳細內(nèi)容,更多關于react vite ts使用.svg的資料請關注腳本之家其它相關文章!
相關文章
React中常見的TypeScript定義實戰(zhàn)教程
這篇文章主要介紹了React中常見的TypeScript定義實戰(zhàn),本文介紹了Fiber結構,F(xiàn)iber的生成過程,調(diào)和過程,以及 render 和 commit 兩大階段,需要的朋友可以參考下2022-10-10
React styled-components設置組件屬性的方法
這篇文章主要介紹了styled-components設置組件屬性的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08
Native?Memory?Tracking追蹤區(qū)域示例分析
這篇文章主要為大家介紹了Native?Memory?Tracking追蹤區(qū)域示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
Vite+React搭建開發(fā)構建環(huán)境實踐記錄
這篇文章主要介紹了Vite+React搭建開發(fā)構建環(huán)境實踐,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09
React Hooks獲取數(shù)據(jù)實現(xiàn)方法介紹
這篇文章主要介紹了react hooks獲取數(shù)據(jù),文中給大家介紹了useState dispatch函數(shù)如何與其使用的Function Component進行綁定,實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2022-10-10
React父組件數(shù)據(jù)實時更新了,子組件沒有更新的問題
這篇文章主要介紹了React父組件數(shù)據(jù)實時更新了,子組件沒有更新的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03

