react antd的关于图标两个小问题

本文介绍如何使用Ant Design的图标组件,通过封装组件实现动态显示图标,以及如何将iconfont资源本地化,解决内网环境下图标加载问题。涵盖组件封装、属性传递、本地资源加载等关键技术点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

根据后台菜单返回的icon字段生成antd icon

先封装成一个组件,根据传入的props icon参数来显示对象的Icon

import React from "react";
import * as Icon from "@ant-design/icons";
const MyIcon = (props) => {
    return (
        React.createElement(
            Icon[props.icon],
            {
                style: {fontSize: '16px'}
            }
        )
    )
};
export default MyIcon;

具体调用的地方例子如下:

 <MyIcon icon={item.icon}/>

item就是后台返回的单个菜单信息,icon就是对应的图标名
举例:某个菜单项

 {
        title: "首页",
        path: "/home",
        icon: "MessageOutlined",
    },

将iconfont.cn 的资源下载到本地,使用createFromIconfontCN 来使用本地资源,解决内网使用iconfont.cn 字体的问题

先把js下载到本地,如图:
js路径
把路径显示的js下载到本地,并放到项目的public文件夹下,
再参照如下demo使用

import React from "react";
import {createFromIconfontCN} from "@ant-design/icons";

const IconFont = createFromIconfontCN({
    scriptUrl: [
        'font.js',//修改成自己的图标文件名
    ],
});

const Home2 = () => {
    return (
        <div className="icons-list">
            <IconFont type="iconconfig"/>
            <IconFont type="iconadd_1"/>
        </div>
    )
};

export default Home2;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值