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,所以就看到乱码

相关推荐
燐妤1 小时前
前端HTML编程3:初识CSS
前端·html5
UXbot1 小时前
独立设计师UI设计工具推荐(2026):支持AI原型生成与代码导出的5款工具全面评价
前端·人工智能·低代码·ui·交互·产品经理·web app
anOnion2 小时前
构建无障碍组件之Table Pattern
前端·html·交互设计
mfxcyh2 小时前
如何把对象数据转化为数组
java·服务器·前端
编程技术手记2 小时前
Vite 开发环境前后端端口隔离:解决 index.html 冲突问题
前端·html
光影少年2 小时前
react16-react19类组件完整生命周期(挂载/更新/卸载)
前端·javascript·react.js
这个昵称也不能用吗?4 小时前
eas 热更新相关
前端
KaMeidebaby4 小时前
卡梅德生物技术快报|葫芦科植物遗传转化:Fast‑TrACC 工程化优化:葫芦科植物遗传转化效率提升与成本控制
前端·其他·百度·新浪微博
换日线°4 小时前
vue 加入购物车抛物线动画
前端·javascript·vue.js