在Vue项目中使用自定义字体的操作步骤

 更新时间:2024年06月30日 14:36:53   作者:吹水一流  
在项目中使用自定义字体可以提升页面的视觉效果,并确保在不同设备上的一致性,文中通过代码示例给出了具体的操作步骤,对大家的学习或工作有一定的帮助,需要的朋友可以参考下

适用场景

  • 多设备兼容:解决不同设备和浏览器中系统字体不一致的问题。
  • 品牌统一:保持品牌的视觉一致性。
  • 高级排版:使用特定的字重和样式,提升排版质量。

解决问题

  • 页面加载性能:通过优化字体文件加载,减少页面渲染阻塞。
  • 视觉一致性:确保字体在各种设备上都能正确显示。
  • 易于维护:通过合理的配置和文件结构,方便后续维护和更新。

下载字体文件

字体格式比较

  • OTF (OpenType Font)

    • 特点:支持高级排版特性,如连字、替代字符。
    • 优点:兼容性好,适用于复杂排版需求。
    • 选择原因:适合需要高质量排版的项目。
  • TTF (TrueType Font)

    • 特点:广泛使用,支持大多数操作系统。
    • 优点:良好的可读性,适合屏幕显示。
    • 缺点:文件相对较大,不支持部分高级排版特性。
  • WOFF/WOFF2 (Web Open Font Format)

    • 特点:专为网页设计,基于压缩的 TTF/OTF。
    • 优点:文件小,加载快,支持现代浏览器。
    • 缺点:不兼容较旧的浏览器。
  • EOT (Embedded OpenType)

    • 特点:微软开发,主要用于旧版 IE 浏览器。
    • 优点:支持 IE 浏览器。
    • 缺点:逐渐被淘汰,不支持其他浏览器。

为什么选择 OTF

我们选择 .otf 格式,因为它支持高级排版功能,兼容性好,适合多种使用场景。虽然 WOFFWOFF2 在网页加载性能上更优,但 .otf 提供了更丰富的排版特性,适合需要高质量排版的项目。

将下载的 .otf 文件放入 src/assets/fonts/ 目录中。

配置 vue.config.js

确保在 vue.config.js 中配置文件加载规则,以正确处理字体文件:

module.exports = {
  chainWebpack: config => {
    config.module
      .rule('fonts')
      .test(/\.(woff2?|eot|ttf|otf)(\?.*)?$/i)
      .use('file-loader')
      .loader('file-loader')
      .options({
        name: 'fonts/[name].[hash:8].[ext]'
      });
  }
};

创建全局 CSS 文件

在 src/assets/styles/ 目录中创建 fonts.css,引入所需的字体:

@font-face {
  font-family: 'NotoSansCJK';
  src: url('@/assets/fonts/NotoSansCJK-Regular-1.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'NotoSansCJK';
  src: url('@/assets/fonts/NotoSansCJK-Bold-6.otf') format('opentype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

body {
  font-family: 'NotoSansCJK', sans-serif;
}

在 main.js 中引入全局 CSS 文件

在 src/main.js 中添加以下代码:

import Vue from 'vue';
import App from './App.vue';
import router from './router';
import store from './store';
import '@/assets/styles/fonts.css';  // 引入全局字体样式

Vue.config.productionTip = false;

new Vue({
  router,
  store,
  render: h => h(App)
}).$mount('#app');

在项目中使用字体

在你的组件中,通过指定 font-family 和 font-weight 使用不同的字重:

<template>
  <div>
    <h1 style="font-weight: 700;">加粗标题</h1>
    <p style="font-weight: 400;">普通文本</p>
  </div>
</template>

优化建议

  • 选择性引入:根据项目需求,仅引入常用的字重(如 Regular 和 Bold),避免加载不必要的字体。

  • 字体压缩:使用工具(如 font-spider)压缩字体文件,减少文件大小,加快加载速度。

npm install font-spider -g
font-spider your-font-file.otf
  • 异步加载:使用 font-display: swap;,允许浏览器在加载字体时使用后备字体,避免文字隐形(FOIT)问题。

  • 使用 CDN:若可能,使用 CDN 提供的字体资源,加快字体加载速度,同时减轻服务器负担。

  • 延迟加载:对于不常用的字体或字重,可以通过懒加载或在非关键路径中使用,以优化首屏性能。

结论

通过以上步骤,可以在 Vue 项目中高效地引入和使用自定义字体。这不仅提升了用户体验,还通过选择性加载和优化技术减少了页面加载时间,确保项目在不同设备上都能呈现一致的视觉效果。

以上就是在Vue项目中使用自定义字体的操作步骤的详细内容,更多关于Vue使用自定义字体的资料请关注脚本之家其它相关文章!

相关文章

  • Vue3中插槽(slot)用法汇总(推荐)

    Vue3中插槽(slot)用法汇总(推荐)

    这篇文章主要介绍了Vue3中插槽(slot)用法汇总,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08
  • antd select 多选限制个数的实现代码

    antd select 多选限制个数的实现代码

    这篇文章主要介绍了antd select 多选限制个数,实现思路和核心代码都很简单,其中核心代码在于disabled,代码简单易懂需要的朋友可以参考下
    2022-11-11
  • 如何利用Vue3管理系统实现动态路由和动态侧边菜单栏

    如何利用Vue3管理系统实现动态路由和动态侧边菜单栏

    通常我们在vue项目中都是前端配置好路由的,但在一些项目中我们可能会遇到权限控制,这样我们就涉及到动态路由的设置了,下面这篇文章主要给大家介绍了关于如何利用Vue3管理系统实现动态路由和动态侧边菜单栏的相关资料,需要的朋友可以参考下
    2022-02-02
  • vue-cli3.0使用及部分配置详解

    vue-cli3.0使用及部分配置详解

    这篇文章主要介绍了vue-cli3.0使用及部分配置详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • VUE组件中的 Drawer 抽屉实现代码

    VUE组件中的 Drawer 抽屉实现代码

    这篇文章主要介绍了VUE组件 之 Drawer 抽屉 ,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • 使用vue实现猜谜卡片游戏

    使用vue实现猜谜卡片游戏

    这篇文章主要为大家详细介绍了如何使用vue实现简单的猜谜卡片游戏,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的小伙伴可以参考一下
    2023-09-09
  • vue深度优先遍历多层数组对象方式(相当于多棵树、三级树)

    vue深度优先遍历多层数组对象方式(相当于多棵树、三级树)

    这篇文章主要介绍了vue深度优先遍历多层数组对象方式(相当于多棵树、三级树),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • Vue 中使用vue2-highcharts实现top功能的示例

    Vue 中使用vue2-highcharts实现top功能的示例

    下面小编就为大家分享一篇Vue 中使用vue2-highcharts实现top功能的示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03
  • 简单理解vue中el、template、replace元素

    简单理解vue中el、template、replace元素

    这篇文章主要帮助大家简单理解vue中el、template、replace元素,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • 深入详解Vue3中的Mock数据模拟

    深入详解Vue3中的Mock数据模拟

    这篇文章主要为大家介绍了深入Vue3中的Mock数据模拟实现细节详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05

最新评论