vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > Vue字体文件打包后fonts文件夹消失

Vue项目字体文件打包后fonts文件夹消失的原因分析与解决方案

作者:Cheney9501

在 Vue 项目中,将字体文件放在 src/assets/fonts 目录下,打包后在浏览器中访问发现路径里不见了 fonts文件夹,这通常不是文件丢失,而是 Vue 的构建工具对静态资源进行了自动化处理,本文给大家介绍了Vue项目字体文件打包后fonts文件夹消失的原因分析与解决方案

问题

在 Vue 项目中,将字体文件放在 src/assets/fonts 目录下,打包后在浏览器中访问发现路径里“不见了 fonts”文件夹,这通常不是文件丢失,而是 Vue 的构建工具(Webpack 或 Vite)对静态资源进行了自动化处理。

导致这种情况主要有以下两个原因:

原因一:小体积字体被转成了 Base64(最常见)

Vue 的构建工具默认会对 assets 目录下的静态资源进行优化。如果你的字体文件体积较小(例如小于 4KB 或 8KB,具体取决于配置),构建工具会直接将其转换成 Base64 编码的字符串,并内嵌到打包后的 CSS 文件中。

原因二:文件被重命名并提取到了根目录

如果字体文件较大,构建工具会将其作为独立的资源文件打包。为了防止浏览器缓存导致更新不生效,构建工具默认会给文件名加上一串哈希值(如 MyFont.a1b2c3d4.woff)。同时,根据你的打包配置,这些资源可能会被直接提取到 dist 的根目录或 static 目录下,而不再保留原本的 fonts 文件夹结构。

如果你确实需要保留fonts目录结构

如果你希望打包后的路径严格保持 /fonts/xxx.woff 的结构,可以通过以下两种方式解决:

方案 1:将字体文件移至 public 目录(推荐)
public 目录下的文件在打包时会原封不动地复制到 dist 目录,不会经过构建工具的处理(不会被转 Base64 或重命名)。

  1. 在根目录的 public 文件夹下新建一个 fonts 文件夹,将字体文件放进去。
  2. 在 CSS 中使用绝对路径引用:
@font-face {
  font-family: 'MyFont';
  /* 这里的 /fonts/ 对应 public/fonts/ */
  src: url('/fonts/MyFont.woff2') format('woff2');
}

方案 2:修改构建配置(针对 Webpack/Vue CLI)
如果你坚持使用 src/assets,可以在 vue.config.js 中修改 url-loaderfile-loader 的配置,强制指定输出目录并关闭 Base64 转换(将 limit 设为 0):

// vue.config.js
module.exports = {
  chainWebpack: config => {
    const fontsRule = config.module.rule('fonts');
    fontsRule.uses.clear(); // 清除默认配置
    fontsRule
      .test(/\.(woff2?|eot|ttf|otf)(\?.*)?$/i)
      .use('url-loader')
      .loader('url-loader')
      .options({
        limit: 0, // 关闭 Base64 转换
        name: 'fonts/[name].[hash:8].[ext]' // 强制输出到 fonts 目录下
      });
  }
};

建议:
你可以先打开浏览器的开发者工具(F12),切换到 Network(网络) 面板,刷新页面查看字体文件是否返回了 200 状态码。如果字体能正常显示且没有报 404 错误,建议保持现状即可,这属于构建工具的正常优化行为。

以上就是Vue项目字体文件打包后fonts文件夹消失的原因分析与解决方案的详细内容,更多关于Vue字体文件打包后fonts文件夹消失的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文