打版时候遇到一个很坑的问题,导致前端的页面字体和图标无法显示。
问题原因很简单,但查找这个问题到定位用了一天时间,醉了。
具体报错:

因为是使用maven打版,
由于maven的filter(拦截),会破坏font文件的二进制文件格式,导致前台解析出错。
而字体和图标文件就在这些二进制文件中,所以需要进行排除。
具体来说,
添加以下代码,到pom文件的<project>标签下的<build>标签里面。
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
<excludes>
<exclude>static/**/*.woff</exclude>
<exclude>static/**/*.woff2</exclude>
<exclude>static/**/*.ttf</exclude>
</excludes>
</resource>
<resource>
<directory>src/main/resources</directory>
<filtering>false</filtering>
<includes>
<include>static/**/*.woff</include>
<include>static/**/*.woff2</include>
<include>static/**/*.ttf</include>
</includes>
</resource>
</resources>
实际上,引起前端报错找不到文件的原因有很多。比如权限控制,或者文件损坏等。但因为打版而引起的几乎就这一个。
如果你打版前好好的,打完本地运行都出问题,清空以后运行又好了,打版后又不行了,那放心,肯定是这个问题。
不谢!
在使用 Maven 打包时遇到一个问题,由于 Maven 的 filter 功能破坏了 font 文件的二进制格式,导致前端页面字体和图标无法正常显示。通过在 pom.xml 文件中添加特定配置,排除字体文件的 filtering,从而解决了这个问题。具体解决方案是在 <build><resources> 标签内添加对 .woff, .woff2 和 .ttf 文件的排除和包含规则。

被折叠的 条评论
为什么被折叠?



