iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >React怎么封装SvgIcon组件
  • 480
分享到

React怎么封装SvgIcon组件

2023-07-05 04:07:29 480人浏览 独家记忆
摘要

本篇内容介绍了“React怎么封装SvgIcon组件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!React优雅的封装SvgIcon组件相信

本篇内容介绍了“React怎么封装SvgIcon组件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

    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文件

    React怎么封装SvgIcon组件

    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

    最终效果:

    React怎么封装SvgIcon组件

    注意可能会遇到的bug

    如果按照以上步骤操作的话,图表还是不出来,有可能是webpack中的配置出来问题;

    一般来说打印requireAll(req)出现以下一个数组才算成功,如果不是,你需要检查下你的webpack是否将svg进行其他操作,导致无法正常解析;

    React怎么封装SvgIcon组件

    出现以下情况,可能你在你的webpack中配置了一些配置项将svg进行base64转码了,导致svg无法正常解析;

    React怎么封装SvgIcon组件

    此时检查你的webpack:

    React怎么封装SvgIcon组件

    “React怎么封装SvgIcon组件”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

    --结束END--

    本文标题: React怎么封装SvgIcon组件

    本文链接: https://www.lsjlt.com/news/349621.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • React怎么封装SvgIcon组件
      本篇内容介绍了“React怎么封装SvgIcon组件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!React优雅的封装SvgIcon组件相信...
      99+
      2023-07-05
    • React优雅的封装SvgIcon组件示例
      目录React如何优雅的封装SvgIcon组件第一步:安装svg-sprite-loader第二步:配置webpack第三步:创建icons/svg文件夹,并且加载所有svg文件第四...
      99+
      2023-02-21
      React封装SvgIcon组件 React封装组件
    • React封装CustomSelect组件思路详解
      目录思路和前提编码与实现处理createContext与useContext对content的封装和拆分: DispatchRender, Controls先说Controls, 包...
      99+
      2022-11-13
    • React+Ts实现二次封装组件
      目录前言样式类型扩展功能扩展 继承 修改 拦截前言 在react中相信大家用的最多的组件库就是Antd了,可是往往在公司的实际开发过程中,我们会发现ui给的设计图和组件有着不小的差别...
      99+
      2023-05-17
      React Ts封装组件 React Ts组件
    • 你知道怎么基于 React 封装一个组件吗
      目录antd 是如何封装组件的仓库地址divider 组件源代码如何暴露组件属性如何设置统一类名前缀如何处理样式与类名divider 组件样式源代码总结前言 很多小伙伴在第一次尝试封...
      99+
      2022-11-13
    • Vue3怎么封装组件
      这篇文章主要讲解了“Vue3怎么封装组件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue3怎么封装组件”吧!例如我们在使用element的标签页tabs组件时,如下图所示:tabs组件可...
      99+
      2023-07-05
    • React封装弹出框组件的方法
      本文实例为大家分享了React封装弹出框组件的方法,供大家参考,具体内容如下 效果图 文件目录 alertList.tsx 用于容纳弹出框的容器 import React f...
      99+
      2022-11-13
    • 怎么封装React Context Composer
      本篇内容主要讲解“怎么封装React Context Composer”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么封装React Context Composer”吧!我是如何一步步封装一...
      99+
      2023-06-22
    • vue3怎么封装ECharts组件
      一、前言前端开发需要经常使用ECharts图表渲染数据信息,在一个项目中我们经常需要使用多个图表,选择封装ECharts组件复用的方式可以减少代码量,增加开发效率。二、封装ECharts组件为什么要封装组件避免重复的工作量,提升复用性使代码...
      99+
      2023-05-20
      Vue3 echarts
    • react结合typescript 封装组件实例详解
      目录项目环境搭建项目依赖项目目录结构创建一个组件封装一个Button组件Button按钮需求分析依赖项目环境搭建 项目依赖 创建支持 TypeScript 的 React 项目 ...
      99+
      2023-05-16
      react typescript 封装组件 react typescript
    • 基于React封装组件的实现步骤
      目录前言antd 是如何封装组件的divider 组件源代码如何暴露组件属性如何设置统一类名前缀如何处理样式与类名divider 组件样式源代码前言 很多小伙伴在第一次尝试封装组件时...
      99+
      2022-11-12
    • react结合typescript封装组件的方法是什么
      今天小编给大家分享一下react结合typescript封装组件的方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。项...
      99+
      2023-07-06
    • 基于React封装一个组件的方法是什么
      这篇文章主要讲解了“基于React封装一个组件的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“基于React封装一个组件的方法是什么”吧!antd 是如何封装组件的仓库地址divi...
      99+
      2023-06-29
    • vue.js中怎么封装table组件
      这篇文章将为大家详细讲解有关vue.js中怎么封装table组件,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。为什么封装首先为什么封装,是因为追求技术吗,不,是因为懒,不想一直的去粘贴,所以...
      99+
      2023-06-20
    • 小程序怎么封装组件
      小编给大家分享一下小程序怎么封装组件,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!微信小程序封装组件具体实现步骤:新建component文件夹存放我们的组件,里边...
      99+
      2023-06-26
    • Vue组件封装怎么实现
      这篇文章主要介绍“Vue组件封装怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue组件封装怎么实现”文章能帮助大家解决问题。一、组件封装的优势复用性:组件封装可以将常用的功能或视图模块抽象...
      99+
      2023-07-05
    • 基于React封装组件的实现步骤是怎样的
      这篇文章将为大家详细讲解有关基于React封装组件的实现步骤是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。前言很多小伙伴在第一次尝试封装组件时会和我一样碰到许多问题,比如人家的组件会...
      99+
      2023-06-21
    • React-View-UI组件库封装Loading加载中源码
      目录组件介绍Loading API能力组件源码组件测试源码组件库线上地址组件介绍 Loading组件是日常开发用的很多的组件,这次封装主要包含两种状态的Loading,旋转、省略号,...
      99+
      2022-11-13
    • React日期时间显示组件的封装方法
      本文实例为大家分享了React日期时间显示组件的封装具体代码,供大家参考,具体内容如下 时间日期展示器 import ProtoType from 'prop-types'; im...
      99+
      2022-11-13
    • VB.NET中怎么实现组件封装
      这篇文章给大家介绍VB.NET中怎么实现组件封装,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。新建一个项目,选择Visual Basic \ Window \ 类库,假设项目名为ClassLibrary1然后 在sol...
      99+
      2023-06-17
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作