我的编程空间,编程开发者的网络收藏夹
学习永远不晚

在Vue.js中加载字体的正确方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

在Vue.js中加载字体的正确方法

添加字体不应该对性能产生负面影响。在本文中,我们将探讨在 Vue 应用程序中加载字体的最佳实践。

正确声明 font-face 的字体

确保正确声明字体是加载字体的重要方面。这是通过使用 font-face 属性来声明你选择的字体来实现的。在你的 Vue 项目中,这个声明可以在你的根 CSS 文件中完成。在进入这个问题之前,我们先来看看 Vue 应用的结构。


/root
 public/
 fonts/
 Roboto/
 Roboto-Regular.woff2
 Roboto-Regular.woff
 index.html
 class="lazy" data-src/
 assets/
 main.css
 components/
 router/
 store/
 views/
 main.js

我们可以像这样在 main.css 中进行 font-face 声明:


// class="lazy" data-src/assets/main.css

@font-face {
 font-family: "Roboto";
 font-weight: 400;
 font-style: normal;
 font-display: auto;
 unicode-range: U+000-5FF;
 class="lazy" data-src: local("Roboto"),
 url("/fonts/Roboto/Roboto-Regular.woff2") format("woff2"),
 url("/fonts/Roboto/Roboto-Regular.woff") format("woff");
}

首先要注意的是 font-display:auto 。使用 auto 作为值可以让浏览器使用最合适的策略来显示字体。这取决于一些因素,如网络速度、设备类型、闲置时间等。

要想更多地控制字体的加载方式,你应该使用 font-display: block ,它指示浏览器短暂地隐藏文本,直到字体完全下载完毕。其他可能的值有 swap 、 fallback 和 optional 。你可以在 这里 阅读更多关于它们的信息。

需要注意的是 unicode-range: U+000-5FF ,它指示浏览器只加载所需的字形范围(U+000 - U+5FF)。你还想使用 woff 和 woff2 字体格式,它们是经过优化的格式,可以在大多数现代浏览器中使用。

另外需要注意的是 class="lazy" data-src 顺序。首先,我们检查字体的本地副本是否可用( local("Roboto”) )并使用它。很多 Android 设备都预装了 Roboto,在这种情况下,我们将使用预装的副本。如果没有本地副本,则在浏览器支持的情况下继续下载 woff2 格式。否则,它会跳至支持的声明中的下一个字体。

预加载字体

一旦你的自定义字体被声明,你可以使用 <link rel="preload"> 告诉浏览器提前预加载字体。在 public/index.html 中,添加以下内容:


<link
 rel="preload"
 as="font"
 href="./fonts/Roboto/Roboto-Regular.woff2"
 type="font/woff2"
 crossorigin="anonymous"
/>

rel = “preload” 指示浏览器尽快开始获取资源, as = “font” 告诉浏览器这是一种字体,因此它优先处理请求。还要注意 crossorigin=“anonymous" ,因为如果没有这个属性,预加载的字体会被浏览器丢弃。这是因为浏览器是以匿名方式获取字体的,所以使用这个属性就可以匿名请求。

使用 link=preload 可以增加自定义字体在需要之前被下载的机会。这个小调整大大加快了字体的加载时间,从而加快了您的 Web 应用程序中的文本渲染。

使用 link = preconnect 托管字体

当使用Google fonts 等网站的托管字体时,你可以通过使用 link=preconnect 来获得更快的加载时间。它告诉浏览器提前建立与域名的连接。

如果您使用的是 Google 字体提供的 Roboto 字体,则可以在 public/index.html 中执行以下操作:


<link rel="preconnect" href="https://fonts.gstatic.com" />
...
<link
 href="https://fonts.googleapis.com/css2?family=Roboto&display=swap"
 rel="stylesheet"
/>

这样就可以建立与原点 https://fonts.gstatic.com 的初始连接,当浏览器需要从原点获取资源时,连接已经建立。从下图中可以看出两者的区别。

当加载字体时没有使用 link=preconnect 时,你可以看到连接所需的时间(DNS 查找、初始连接、SSL 等)。当像这样使用 link=preconnect 时,结果看起来非常不同。

在这里,你会发现 DNS 查找、初始连接和 SSL 所花费的时间已经不存在了,因为前面已经进行了连接。

使用 service workers 缓存字体

字体是静态资源,变化不大,所以它们是缓存的好候选。理想情况下,您的 Web 服务器应该为字体设置一个较长的 max-age expires 头,这样浏览器缓存字体的时间就会更长。如果你正在构建一个渐进式网络应用(PWA),那么你可以使用 service workers 来缓存字体,并直接从缓存中为它们提供服务。

要开始使用 Vue 构建 PWA,请使用 vue-cli 工具生成一个新项目:


vue create pwa-app

选择 Manually select features 选项,然后选择 Progressive Web App (PWA) Support :

这些就是我们生成 PWA 模板所需要的唯一东西。完成后,你就可以把目录改为 pwa-app ,然后为 app 服务。


cd pwa-app
yarn serve

你会注意到在 class="lazy" data-src 目录下有一个文件 registerServiceWorker ,其中包含了默认的配置。在项目的根目录下,如果 vue.config.js 不存在,请创建它,如果存在,请添加以下内容:


// vue.config.js
module.exports = {
 pwa: {
 workboxOptions: {
 skipWaiting: true,
 clientsClaim: true,
 },
 },
};

vue-cli 工具使用PWA plugin 生成 service worker。在底层,它使用 Workbox 来配置 service worker 和它控制的元素、要使用的缓存策略以及其他必要的配置。

在上面的代码片段中,我们要确保我们的应用程序始终由 service worker 的最新版本控制。这是必要的,因为它确保我们的用户总是查看应用程序的最新版本。您可以签出 Workbox 配置文档,以获得对生成的 service worker 行为的更多控制。

接下来,我们将自定义字体添加到 public 目录。我有以下结构:


root/
 public/
 index.html
 fonts/
 Roboto/
 Roboto-Regular.woff
 Roboto-Regular.woff2

一旦完成了 Vue 应用程序的开发,就可以通过从终端运行以下命令来构建它:


yarn build

这将结果输出到 dist 文件夹中。如果你检查文件夹的内容,你会注意到一个类似于 precache-manifest.1234567890.js 的文件。它包含了要缓存的资产列表,这只是一个包含修订版和 URL 的键值对的列表。


self.__precacheManifest = (self.__precacheManifest || []).concat([
 {
 "revision": "3628b4ee5b153071e725",
 "url": "/fonts/Roboto/Roboto-Regular.woff2"
 },
 ...
]);

public/ 文件夹中的所有内容都是默认缓存的,其中包括自定义字体。有了这个地方,你可以用像 service 这样的包来 serve 你的应用程序,或者把 dist 文件夹托管在 web 服务器上查看结果。你可以在下面找到一个应用程序的截图。

在随后的访问中,字体是从缓存中加载的,这可以加快应用程序的加载时间。

结论

在这篇文章中,我们研究了在 Vue 应用程序中加载字体时应用的一些最佳实践。使用这些实践将确保你提供的字体看起来不错,而不影响应用的性能。

到此这篇关于在Vue.js中加载字体的正确方法的文章就介绍到这了,更多相关vue.js 加载字体内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

在Vue.js中加载字体的正确方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

在Vue.js中如何加载字体

小编给大家分享一下在Vue.js中如何加载字体,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!添加字体不应该对性能产生负面影响。在本文中,我们将探讨在 Vue 应用
2023-06-14

Android中正确使用字体图标(iconfont)的方法

字体图标 字体图标是指将图标做成字体文件(.ttf),从而代替传统的png等图标资源。 使用字体图标的优点和缺点分别为: 优点: 1. 可以高度自定义图标的样式(包括大小和颜色),对于个人开发者尤其适用 2. 可以减
2022-06-06

ubuntu加载中文字体的方法是什么

这篇“ubuntu加载中文字体的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“ubuntu加载中文字体的方法是什么
2023-07-04

正确定义变量的方法在Golang中

Golang中如何正确定义变量,需要具体代码示例在Golang中,正确的变量定义是保证代码质量和可读性的关键之一。良好的变量定义能够增加代码的可维护性和可扩展性。本文将介绍Golang中如何正确定义变量,并提供具体的代码示例。使用关键字v
正确定义变量的方法在Golang中
2024-01-18

Android实现加载时提示“正在加载,请稍后”的方法

前言 这篇文章主要介绍的是,如何实现点击按钮,弹出“正在加载数据,请稍候…”对话框,加载完了之后,对话框自动消失呢? 其实也是很简单的看下面代码:import com.farsunset.ichat.example.R; import an
2022-06-06

WordPress文章标题链接添加正在加载中提示的方法

本文实例讲述了WordPress文章标题链接添加正在加载中提示的方法。分享给大家供大家参考。具体分析如下: 我们会看到很多使用wordpress博客的朋友我们点击文章标题时就会先提示正在加载中,然后再进入文章了,这里我们就来给大家介绍Wor
2022-06-12

在React Native中添加自定义字体的方法详解

ReactNative添加自定义字体指南:在ReactNative中添加自定义字体至关重要,允许您使用符合品牌特色的唯一字体。步骤:获取字体文件(.ttf或.otf)。将文件添加到项目assets/fonts文件夹。创建字体常量,引用文件路径。使用useFonts钩子加载字体。在样式中使用字体名称应用。考虑因素:平台支持:确保字体适用于目标平台。许可证:检查字体许可限制。性能:仅加载必需字体,避免影响性能。命名约定:使用一致的命名约定。可扩展性:后续添加字体时,按照相同步骤更新字体常量。
在React Native中添加自定义字体的方法详解
2024-04-02

ReactNative中添加自定义字体的方法

这篇文章主要介绍了如何在ReactNative中添加自定义字体,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-11-13

C#从UTF-8流中读取字符串的正确方法是什么

本篇内容介绍了“C#从UTF-8流中读取字符串的正确方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 我们下面的代码是从一个流 st
2023-06-25

编程热搜

目录