import React, { useState, useEffect, FC } from "react"; import { Block, View } from "@tarojs/components"; import "./iconfont.scss"; import Taro from "@tarojs/taro"; import classnames from "classnames"; const SystemWidth = Taro.getSystemInfoSync().windowWidth const quot = '"' function hex2rgb(hex) { var rgb = []; hex = hex.substr(1); if (hex.length === 3) { hex = hex.replace(/(.)/g, "$1$1"); } hex.replace(/../g, function(color: string) { rgb.push(parseInt(color, 0x10)); return color; }); return "rgb(" + rgb.join(",") + ")"; } export type IconNames = 'icon-zhankai1' | 'icon-shouqi1' | 'icon-shouhou1' | 'icon-cangku1' | 'icon-saoma' | 'icon-dizhi1' | 'icon-huodaofukuan' | 'icon-yufukuan1' | 'icon-yue' | 'icon-zidingyi' | 'icon-jinetiaozheng' | 'icon-tuikuan1' | 'icon-zhankai' | 'icon-shouqi' | 'icon-lujing' | 'icon-jizhumima' | 'icon-a-jizhumima' | 'icon-weixindenglu' | 'icon-kehuxinxi' | 'icon-yewuyuanqizi' | 'icon-chakanquanbukehu' | 'icon-biyan' | 'icon-bianji' | 'icon-daikuan' | 'icon-cangku' | 'icon-guanlidingdan' | 'icon-mima' | 'icon-guanbi' | 'icon-jianshao' | 'icon-dingwei' | 'icon-saomiao' | 'icon-peihuo' | 'icon-shaixuan' | 'icon-paiming' | 'icon-shanchusousuoxinxi' | 'icon-shijian' | 'icon-sousuo' | 'icon-shouhou' | 'icon-sousuofanhui' | 'icon-sousuoshanchu' | 'icon-tuikuan' | 'icon-tishi' | 'icon-xianxiahuizong' | 'icon-xinzeng' | 'icon-yonghuming' | 'icon-yanjing' | 'icon-yufukuan' | 'icon-wodekefu' | 'icon-dizhi' | 'icon-shouhouzhongxin' | 'icon-wodeshoucang' | 'icon-shoukuanliebiao' | 'icon-madanguanli' | 'icon-qusechazhao' | 'icon-pandiansaoma' | 'icon-yaoqingma' | 'icon-duizhang' | 'icon-tihuoliebiao' | 'icon-yangpinduibi' | 'icon-yansequyang' | 'icon-fahuoliebiao' | 'icon-yuncangkucun' | 'icon-xiaoshou' | 'icon-qianzhicangkucun' | 'icon-lingquseka' | 'icon-gouwu1' | 'icon-dingdan1' | 'icon-gerenzhongxin1' | 'icon-shouye1' | 'icon-gerenzhongxin' | 'icon-dingdan' | 'icon-shouye' | 'icon-gouwu'; type PropsType = { name: IconNames; size?: number; color?: string | string[]; customStyle?: React.CSSProperties; customClassName?: string; }; const IconFont:FC = ({ name, size = 36, color, customStyle = {}, customClassName = "" }) => { const [colors, setColors] = useState() const [isStr, setIsStr] = useState(true) const [svgSize, setSvgSize] = useState(() => (size / 750) * SystemWidth) useEffect(() => { setIsStr(typeof color === 'string') if (typeof color === 'string') { setColors(color.indexOf('#') === 0 ? hex2rgb(color) : color) } else { setColors( color?.map(function (item) { return item.indexOf('#') === 0 ? hex2rgb(item) : item }) ) } return () => {} }, [color]) useEffect(() => { setSvgSize((size / 750) * SystemWidth) }, [size]) // 也可以使用 if (name === 'xxx') { return } 来渲染,但是测试发现在ios下会有问题,报错 Maximum call stack啥的。下面这个写法没问题 return ( {/* icon-alipay */} {/* {name === "icon-alipay" && ( )} */} {/* icon-zhankai1 */} { name === 'icon-zhankai1' && () } {/* icon-shouqi1 */} { name === 'icon-shouqi1' && () } {/* icon-shouhou1 */} { name === 'icon-shouhou1' && () } {/* icon-cangku1 */} { name === 'icon-cangku1' && () } {/* icon-saoma */} { name === 'icon-saoma' && () } {/* icon-dizhi1 */} { name === 'icon-dizhi1' && () } {/* icon-huodaofukuan */} { name === 'icon-huodaofukuan' && () } {/* icon-yufukuan1 */} { name === 'icon-yufukuan1' && () } {/* icon-yue */} { name === 'icon-yue' && () } {/* icon-zidingyi */} { name === 'icon-zidingyi' && () } {/* icon-jinetiaozheng */} { name === 'icon-jinetiaozheng' && () } {/* icon-tuikuan1 */} { name === 'icon-tuikuan1' && () } {/* icon-zhankai */} { name === 'icon-zhankai' && () } {/* icon-shouqi */} { name === 'icon-shouqi' && () } {/* icon-lujing */} { name === 'icon-lujing' && () } {/* icon-jizhumima */} { name === 'icon-jizhumima' && () } {/* icon-a-jizhumima */} { name === 'icon-a-jizhumima' && () } {/* icon-weixindenglu */} { name === 'icon-weixindenglu' && () } {/* icon-kehuxinxi */} { name === 'icon-kehuxinxi' && () } {/* icon-yewuyuanqizi */} { name === 'icon-yewuyuanqizi' && () } {/* icon-chakanquanbukehu */} { name === 'icon-chakanquanbukehu' && () } {/* icon-biyan */} { name === 'icon-biyan' && () } {/* icon-bianji */} { name === 'icon-bianji' && () } {/* icon-daikuan */} { name === 'icon-daikuan' && () } {/* icon-cangku */} { name === 'icon-cangku' && () } {/* icon-guanlidingdan */} { name === 'icon-guanlidingdan' && () } {/* icon-mima */} { name === 'icon-mima' && () } {/* icon-guanbi */} { name === 'icon-guanbi' && () } {/* icon-jianshao */} { name === 'icon-jianshao' && () } {/* icon-dingwei */} { name === 'icon-dingwei' && () } {/* icon-saomiao */} { name === 'icon-saomiao' && () } {/* icon-peihuo */} { name === 'icon-peihuo' && () } {/* icon-shaixuan */} { name === 'icon-shaixuan' && () } {/* icon-paiming */} { name === 'icon-paiming' && () } {/* icon-shanchusousuoxinxi */} { name === 'icon-shanchusousuoxinxi' && () } {/* icon-shijian */} { name === 'icon-shijian' && () } {/* icon-sousuo */} { name === 'icon-sousuo' && () } {/* icon-shouhou */} { name === 'icon-shouhou' && () } {/* icon-sousuofanhui */} { name === 'icon-sousuofanhui' && () } {/* icon-sousuoshanchu */} { name === 'icon-sousuoshanchu' && () } {/* icon-tuikuan */} { name === 'icon-tuikuan' && () } {/* icon-tishi */} { name === 'icon-tishi' && () } {/* icon-xianxiahuizong */} { name === 'icon-xianxiahuizong' && () } {/* icon-xinzeng */} { name === 'icon-xinzeng' && () } {/* icon-yonghuming */} { name === 'icon-yonghuming' && () } {/* icon-yanjing */} { name === 'icon-yanjing' && () } {/* icon-yufukuan */} { name === 'icon-yufukuan' && () } {/* icon-wodekefu */} { name === 'icon-wodekefu' && () } {/* icon-dizhi */} { name === 'icon-dizhi' && () } {/* icon-shouhouzhongxin */} { name === 'icon-shouhouzhongxin' && () } {/* icon-wodeshoucang */} { name === 'icon-wodeshoucang' && () } {/* icon-shoukuanliebiao */} { name === 'icon-shoukuanliebiao' && () } {/* icon-madanguanli */} { name === 'icon-madanguanli' && () } {/* icon-qusechazhao */} { name === 'icon-qusechazhao' && () } {/* icon-pandiansaoma */} { name === 'icon-pandiansaoma' && () } {/* icon-yaoqingma */} { name === 'icon-yaoqingma' && () } {/* icon-duizhang */} { name === 'icon-duizhang' && () } {/* icon-tihuoliebiao */} { name === 'icon-tihuoliebiao' && () } {/* icon-yangpinduibi */} { name === 'icon-yangpinduibi' && () } {/* icon-yansequyang */} { name === 'icon-yansequyang' && () } {/* icon-fahuoliebiao */} { name === 'icon-fahuoliebiao' && () } {/* icon-yuncangkucun */} { name === 'icon-yuncangkucun' && () } {/* icon-xiaoshou */} { name === 'icon-xiaoshou' && () } {/* icon-qianzhicangkucun */} { name === 'icon-qianzhicangkucun' && () } {/* icon-lingquseka */} { name === 'icon-lingquseka' && () } {/* icon-gouwu1 */} { name === 'icon-gouwu1' && () } {/* icon-dingdan1 */} { name === 'icon-dingdan1' && () } {/* icon-gerenzhongxin1 */} { name === 'icon-gerenzhongxin1' && () } {/* icon-shouye1 */} { name === 'icon-shouye1' && () } {/* icon-gerenzhongxin */} { name === 'icon-gerenzhongxin' && () } {/* icon-dingdan */} { name === 'icon-dingdan' && () } {/* icon-shouye */} { name === 'icon-shouye' && () } {/* icon-gouwu */} { name === 'icon-gouwu' && () } ) } export default IconFont