日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

React優雅的封裝SvgIcon組件示例

瀏覽:362日期:2022-06-01 08:52:51
目錄
  • React如何優雅的封裝SvgIcon組件
    • 第一步:安裝svg-sprite-loader
    • 第二步:配置webpack
    • 第三步:創建icons/svg文件夾,并且加載所有svg文件
    • 第四步:創建 SvgIcon 組件
    • 第五步:在組件中使用 SvgIcon
    • 注意可能會遇到的bug
  • 總結

    React如何優雅的封裝SvgIcon組件

    相信使用過vue的伙伴們,或多或少都接觸或使用過vue-element-admin,其中許多封裝都不禁讓人拍案叫絕,因為本人之前是vue入門前端的,所以對vue-element-admin許多封裝印象深刻,現在從vuereact之后,一直想把vue-element-admin里面的封裝組件復刻到react當中使用,這次是SvgIcon組件的react封裝版本;

    第一步:安裝svg-sprite-loader

    • npm 安裝
    npm i svg-sprite-loader -D
    • yarn 安裝
    yarn add svg-sprite-loader -D

    第二步:配置webpack

          {test: /.svg$/,loader: "svg-sprite-loader",include: path.resolve(__dirname, "../src/icons"), options: {  symbolId: "icon-[name]" }      },      {test: /.(eot|woff2?|ttf|svg)$/,exclude: path.resolve(__dirname, "../src/icons"), // 不處理 svg類型文件use: [  {    loader: "url-loader",    options: {      name: "[name]-[hash:5].min.[ext]",      limit: 10000,      outputPath: "font",      publicPath: "font"    }  }]      },

    第三步:創建icons/svg文件夾,并且加載所有svg文件

    index.ts中方法

    const requireAll = (requireContext: __WebpackModuleApi.RequireContext) =>  requireContext.keys().map(requireContext)const req = require.context("./svg", false, /.svg$/)requireAll(req)export {} // 默認到處,ts如若不導出,會警告

    第四步:創建 SvgIcon 組件

    import React from "react"import PropTypes from "prop-types"import "./index.scss"const SvgIcon = (props: { iconClass: string; svgClass: string; fill: string ;click: MouseEventHandler<HTMLElement>}) => {  const { iconClass, fill, svgClass,click } = props  return (    <i aria-hidden="true" onClick={click}>      <svg className={`svg-class ${svgClass}`}><use xlinkHref={"#icon-" + iconClass} fill={fill} />      </svg>    </i>  )}SvgIcon.propTypes = {  // svg名字  iconClass: PropTypes.string.isRequired,  // 自定義類名  svgClass: PropTypes.string,    //自定義方法  click: PropTypes.func,  // 填充顏色  fill: PropTypes.string,}SvgIcon.defaultProps = {  fill: "currentColor",  svgClass: "",  click: () => {},}export default SvgIcon

    第五步:在組件中使用 SvgIcon

    import React from "react"import SvgIcon from "@/components/SvgIcon"const Index = () => {  return (    <div>      <SvgIcon iconClass="礦泉水" />    </div>  )}export default Index

    最終效果:

    注意可能會遇到的bug

    如果按照以上步驟操作的話,圖表還是不出來,有可能是webpack中的配置出來問題;

    一般來說打印requireAll(req)出現以下一個數組才算成功,如果不是,你需要檢查下你的webpack是否將svg進行其他操作,導致無法正常解析;

    出現以下情況,可能你在你的webpack中配置了一些配置項將svg進行base64轉碼了,導致svg無法正常解析;

    此時檢查你的webpack:

    總結

    以上就是個人在react中模擬vue-element-admin封裝SvgIcon組件,以后個人會帶來更多的組件封裝,更多關于React封裝SvgIcon組件的資料請關注其它相關文章!

    標簽: JavaScript
    日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
    欧美久久天堂| 美女视频网站久久| 精品欧美日韩精品| 香蕉久久久久久| 视频一区二区欧美| 日本高清久久| 日韩毛片一区| 国产欧美精品久久| 亚洲男人在线| 日韩av一二三| 国产美女久久| 久久亚洲成人| 亚洲视频国产| 色婷婷色综合| 成人av二区| 日韩精品a在线观看91| 国产精品一区二区美女视频免费看 | 免费在线看一区| 免费视频最近日韩| 久久精品欧洲| 亚洲欧美伊人| 日韩av二区在线播放| 麻豆极品一区二区三区| 色婷婷亚洲mv天堂mv在影片| 午夜国产精品视频| 日韩av二区在线播放| 精品亚洲成人| 亚洲精品裸体| 国产欧美视频在线| 天堂av在线| 亚洲精品乱码日韩| 国产亚洲人成a在线v网站| 久久久国产精品网站| 丝袜av一区| 久久国内精品自在自线400部| 欧美日韩激情| 中文字幕在线看片| 久久免费精品| 色婷婷成人网| 精品一区二区三区在线观看视频| 久久在线免费| 在线中文字幕播放| 久久97视频| 日本国产欧美| 三级亚洲高清视频| 欧美日韩国产传媒| 啪啪亚洲精品| 最新日韩欧美| 99精品电影| 国产日韩欧美一区二区三区在线观看| 99国产一区| 久久久久国产精品一区三寸| 国产精品大片免费观看| 欧美在线91| 欧美日本不卡| 国产精品久一| 久久激情综合网| 国产精品调教| 亚洲永久av| 香蕉视频亚洲一级| 美女在线视频一区| 亚洲精品国产精品粉嫩| 樱桃成人精品视频在线播放| 999久久久国产精品| 99久久婷婷这里只有精品| 久久久久午夜电影| 欧美亚洲国产精品久久| 欧洲在线一区| 日韩免费av| 亚洲成人va| 石原莉奈在线亚洲三区| 日韩福利视频导航| 麻豆一区二区在线| 欧美激情视频一区二区三区免费 | 国产主播一区| 欧美~级网站不卡| 蜜臀av国产精品久久久久 | 欧美激情在线精品一区二区三区| 日韩精品1区2区3区| 精品国产麻豆| 色乱码一区二区三区网站| 国产亚洲网站| 国产精品色在线网站| 性欧美videohd高精| 欧美日韩中文一区二区| 日韩亚洲在线| 麻豆成人av在线| 激情综合激情| 99在线精品免费视频九九视| 国产欧美视频在线| 久久精品91| 人人爱人人干婷婷丁香亚洲| 精品视频91| 亚洲在线观看| 久久不见久久见免费视频7| 激情久久久久久| 国产精品入口久久| 成人在线黄色| 亚洲精品888| 日韩精品久久理论片| 国产一区福利| 91在线成人| 999视频精品| 国产欧美日韩精品高清二区综合区| 黑人精品一区| 国产精品久久久久久久久久妞妞| 黄色亚洲在线| 免费高潮视频95在线观看网站| 日本国产欧美| 亚洲欧美久久久| 久久国产影院| 国产激情在线播放| 国产欧美日韩精品一区二区免费| 中文精品视频| 国产丝袜一区| 亚洲精品在线国产| 另类国产ts人妖高潮视频| 日韩欧美精品一区| 日韩超碰人人爽人人做人人添| 91久久视频| 亚洲天堂资源| 国产精品久久久久久久久久白浆 | 精品三级av在线导航| 日韩中文字幕91| 中文字幕在线高清| 日本蜜桃在线观看视频| 国产探花一区在线观看| 日本午夜精品一区二区三区电影| 亚洲精品第一| 蜜桃av一区二区在线观看| 九一精品国产| 欧美精品一卡| 亚洲二区免费| 99精品在线观看| 风间由美中文字幕在线看视频国产欧美| 欧美日韩午夜| 日韩av不卡一区二区| 亚洲精品乱码日韩| 欧美日韩网址| 午夜亚洲福利| 日韩黄色免费网站| 久久精品国产成人一区二区三区| 麻豆91精品视频| 97人人精品| 欧美日韩国产免费观看视频| 日韩精品导航| 国产精品99久久免费| 国产成人精品免费视| 国产成人精选| 国内精品99| 久久午夜影视| 国产日韩亚洲| 成人台湾亚洲精品一区二区| 在线看片国产福利你懂的| 老色鬼精品视频在线观看播放| 欧美国产另类| 日韩中文字幕区一区有砖一区 | 日韩激情精品| 国产情侣久久| 精品国产欧美日韩| 国产综合精品一区| 久久aⅴ国产紧身牛仔裤| 亚洲精品乱码久久久久久蜜桃麻豆 | 日韩毛片视频| 亚洲精品第一| www在线观看黄色| 亚洲欧美日韩综合国产aⅴ| 欧美日韩一视频区二区| 成人三级高清视频在线看| 日韩中文字幕91| 91精品国产91久久久久久黑人| 日本一区二区中文字幕| 国产中文字幕一区二区三区| 一本综合精品| 日韩av资源网| 欧美va天堂在线| 麻豆国产精品视频| 日韩精品视频一区二区三区| 日韩深夜视频| 久久97久久97精品免视看秋霞| 国产精品婷婷| 新版的欧美在线视频| 在线一区二区三区视频| 久久男人天堂| 视频福利一区| 精品久久国产一区| 国产精品jk白丝蜜臀av小说| 视频一区在线播放| 亚洲特色特黄| a国产在线视频| 欧美国产三级| 国产精品久久久久久模特| 久久国产精品免费一区二区三区 | 鲁大师影院一区二区三区| 日韩综合精品| 四虎4545www国产精品| 国产视频网站一区二区三区| 亚洲不卡视频| 亚洲国产不卡| 在线免费观看亚洲|