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