SVG 图标插件误读 PNG 图片 + Vite 重启缓存失效重新生成 + 浏览器严格渲染

浏览器刷新会出现满屏乱码字符,刷新成功后就会出现页面

检查Doc标签页(Chrome DevTools 里专门显示页面主文档请求 的地方,它在 Network 面板的顶部标签栏里)

发现在Preview预览当中就出现了乱码

发现Response当中HTML 源代码直接嵌入了PNG图片的二进制乱码

导致这个问题的真凶

1.首先是把png图片和svg都放在一个icons文件夹当中

2.在vite.config.ts当中写入了svgBuilder('./src/assets/icons/'),

因为 svgBuilder 只会处理 SVG 文件,但你文件夹里有 PNG 图片,它不认识 PNG,就直接把图片的二进制内容当成文本塞进页面里了 → 于是页面出现 �PNG 乱码!

svgBuilder 是干什么的?

它的作用只有一个:/src/assets/icons/ 里的 .svg 文件,自动变成组件,注入到页面 <body> 里。但是他只认识SVG。

解决方法

1.不修改配置文件 不要把png和svg放在一个文件夹当中,尤其是在配置文件当中svgBuilder声明的

2.修改配置文件,注释svgBuilder

总结

这个问题是在电脑关机后 重新运行这个项目产生的,是因为Vite 有缓存,电脑关机/重启都会将vite的内存缓存清理 当重新运行该项目,没有缓存了 必须重新生成,svgBuilder识别到了png图片,将二进制乱码塞进 HTML,所以就看到乱码

相关推荐
NiceCloud喜云6 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby7 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
丷丩7 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
Front思8 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫10 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。11 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星11 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒11 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩11 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi11 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具