iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >在Vue.js中如何加载字体
  • 740
分享到

在Vue.js中如何加载字体

2023-06-14 10:06:42 740人浏览 八月长安
摘要

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

小编给大家分享一下在vue.js中如何加载字体,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

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

在Vue.js中如何加载字体

正确声明 font-face 的字体

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

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

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

// src/assets/main.css@font-face { font-family: "Roboto"; font-weight: 400; font-style: nORMal; font-display: auto; unicode-range: U+000-5FF; 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 字体格式,它们是经过优化的格式,可以在大多数现代浏览器中使用。

另外需要注意的是 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 的初始连接,当浏览器需要从原点获取资源时,连接已经建立。从下图中可以看出两者的区别。

在Vue.js中如何加载字体

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

在Vue.js中如何加载字体

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

在Vue.js中如何加载字体

使用 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 :

在Vue.js中如何加载字体

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

cd pwa-appyarn serve

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

// vue.config.jsmodule.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.js中如何加载字体

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

以上是“在Vue.js中如何加载字体”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: 在Vue.js中如何加载字体

本文链接: https://www.lsjlt.com/news/270064.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 在Vue.js中如何加载字体
    小编给大家分享一下在Vue.js中如何加载字体,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!添加字体不应该对性能产生负面影响。在本文中,我们将探讨在 Vue 应用...
    99+
    2023-06-14
  • 在Vue.js中加载字体的正确方法
    目录正确声明 font-face 的字体预加载字体使用 link = preconnect 托管字体使用 service workers 缓存字体结论添加字体不应该对性能产生负面影响...
    99+
    2024-04-02
  • ubuntu如何加载中文字体
    ubuntu加载中文字体的方法:在ubuntu上打开终端窗口。输入以下命令查看系统类型。cat /proc/version查看中文字体。fc-list :lang=zh-cn如果出现拉乱码,则说明需要安装中文字体。//安装命令sudo ap...
    99+
    2024-04-02
  • 如何加载web字体
    本篇文章给大家分享的是有关如何加载web字体,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一般来说,开发者对网页字体使用会相对接触比较少一些,使用最多也无非是 font-fam...
    99+
    2023-06-09
  • css如何加载外部字体文件
    这篇文章主要介绍“css如何加载外部字体文件”,在日常操作中,相信很多人在css如何加载外部字体文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css如何加载外部字体文件”...
    99+
    2024-04-02
  • css中字体如何加横线
    在css中给字体添加横线的方法:1.创建p标签;2.使用text-decoration属性添加字体横线;在css中给字体添加横线的方法首先,在页面中创建两个p标签,并添加文字用于对比;<!DOCTYPE html>&l...
    99+
    2024-04-02
  • Vue.js在页面加载时如何执行某个方法
    这篇文章主要介绍了Vue.js在页面加载时如何执行某个方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。jQuery中可以这样写vue中,如...
    99+
    2024-04-02
  • 如何在Python中快速加载Git关键字?
    在开发过程中,Git是一个非常重要的工具,它可以有效地管理项目的版本和修改记录。在Python中,我们可以使用Git来进行版本控制和协作开发。但是,如果我们需要在Python中快速加载Git关键字,该怎么办呢?在本文中,我们将介绍Pyth...
    99+
    2023-09-18
    git load 关键字
  • 如何在Ubuntu上添加安装字体
    本篇内容介绍了“如何在Ubuntu上添加安装字体”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Ubuntu的美化当然少不了漂亮字体的支持,我...
    99+
    2023-06-13
  • java swing如何实现加载自定义的字体
    这篇文章主要介绍了java swing如何实现加载自定义的字体,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。java swing 加载自定义的字体在实际开发中, 我们需要把字...
    99+
    2023-06-25
  • Dreamweaver如何添加字体
    这篇文章主要介绍了Dreamweaver如何添加字体,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。方法如下首先打开Dreamweaver界面,你想换字体的话,现在不用先选中。...
    99+
    2023-06-08
  • html字体如何加粗
    小编给大家分享一下html字体如何加粗,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!html字体加粗的方法:首先创建一个HTML示例文件;然后通过p标签创建一个普...
    99+
    2023-06-15
  • css中如何给字体加描边
    在css中给字体添加描边的方法:1.创建p标签;2.使用text-shadow属性添加描边;在css中给字体添加描边的方法首先,在页面中创建两个p标签,并添加文字用于对比;<!DOCTYPE html><html...
    99+
    2024-04-02
  • 如何在spring中加载bean
    这篇文章给大家介绍如何在spring中加载bean,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一:spring读取配置或注解的过程先通过扫描指定包路径下的spring注解,比如@Component、@Service、...
    99+
    2023-06-15
  • 如何在java中加载类
    今天就跟大家聊聊有关如何在java中加载类,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。类加载器类加载器作用负责将.class文件(存储的物理文件)加载到内存中类加载器过程加载:通过...
    99+
    2023-06-15
  • 如何在Python中有效地加载Git关键字?
    在Git中,关键字是指能够在代码中引起注意的词汇或短语。这些关键字包括了一些特殊的命令和参数,能够帮助我们更好地管理代码仓库。在Python中,我们可以通过使用GitPython模块来加载Git关键字,从而实现更加高效的代码管理。下面,我...
    99+
    2023-09-18
    git load 关键字
  • windows coreldraw如何下载字体
    这篇文章主要介绍“windows coreldraw如何下载字体”,在日常操作中,相信很多人在windows coreldraw如何下载字体问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”windows cor...
    99+
    2023-07-01
  • 如何在Fragment中加载PreferenceFragment
    要在Fragment中加载PreferenceFragment,可以按照以下步骤进行操作:1. 创建一个PreferenceFrag...
    99+
    2023-09-27
    Fragment
  • 如何在css中设置字体
    本篇文章给大家分享的是有关如何在css中设置字体,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、font标签配置字体<font face="字体样式...
    99+
    2023-06-15
  • CSS字体中加载加速问题的示例分析
    这篇文章将为大家详细讲解有关CSS字体中加载加速问题的示例分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。除了各种特定字体系列外(如 Times、Verd...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作