【Electron】解决Electron使用阿里iconfont不生效问题(react+vite)

解决Electron使用阿里iconfont不生效问题

问题描述

Electron应用打包后,生产环境渲染层无法加载本地iconfont资源。

javascript 复制代码
import { createFromIconfontCN } from '@ant-design/icons'
const IconFont = createFromIconfontCN({
  scriptUrl: '/iconfont/iconfont.js',
})

查看控制台,发现iconfont.js资源加载失败

这是由于页面加载 iconfont.js/iconfont.css 时,如果路径是绝对路径 /iconfont/iconfont.js 或相对 HTTP 地址,Electron 在本地 file:// 协议下会解析错误。

解决方案

  1. 从 iconfont 下载项目的所有文件(JS/CSS/SVG 等)。
  2. 把这些文件放到 electron-egg 项目的 前端静态目录(比如 app/web/public/iconfont/)。
  3. 在前端代码引用相对路径,例如:
javascript 复制代码
import { createFromIconfontCN } from '@ant-design/icons'
const IconFont = createFromIconfontCN({
  scriptUrl: './iconfont/iconfont.js',
})

此时再看控制台,加载成功

注意事项:

  1. iconfont资源必须要放在public目录下,Vite 会让这个目录里的文件原样复制到打包的 dist,并且开发服务器也能直接访问。
  2. 确保 Vite 基础路径正确
javascript 复制代码
// vite.config.js
import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'

export default defineConfig({
  plugins: [react()],
  base: './', // 或 '/app/',根据部署路径来设置
})
  1. 不能只放iconfont.js文件,css、woff等文件也要放在iconfont目录下,否则会有样式问题
  2. 可以将路径写在环境变量中,方便开发环境调试,不用频繁下载压缩包
javascript 复制代码
const IconFont = createFromIconfontCN({
  scriptUrl: import.meta.env.VITE_ICONFONT_URL,
})
相关推荐
Hamm1 小时前
不想花一分钱玩 OpenClaw?来,一起折腾这个!
javascript·人工智能·agent
Setsuna_F_Seiei1 小时前
AI 对话应用之 JS 的流式接口数据处理
前端·javascript·ai编程
英俊潇洒美少年2 小时前
react如何实现 vue的$nextTick的效果
javascript·vue.js·react.js
隔壁小邓5 小时前
前端Vue项目打包部署实战教程
前端·javascript·vue.js
TON_G-T6 小时前
javascript中 Iframe 处理多端通信、鉴权
开发语言·前端·javascript
周淳APP6 小时前
【JS之闭包防抖节流,this指向,原型&原型链,数据类型,深浅拷贝】简单梳理啦!
开发语言·前端·javascript·ecmascript
kyriewen6 小时前
console.log 骗了我一整个通宵:原来它才是时间旅行者
前端·javascript·chrome
冴羽6 小时前
在浏览器控制台调试的 6 个秘密技巧
前端·javascript·chrome
前端Hardy6 小时前
别再手动调 Prompt 了!这款开源神器让 AI 输出质量提升 300%,支持 Claude、GPT、Gemini,还免费开源!
前端·javascript·面试
敲代码的约德尔人6 小时前
React 性能优化完全指南:从渲染机制到实战技巧
react.js