一行代码搞定,前端全局修改自定义字体极速体验

本文主要是介绍一行代码搞定,前端全局修改自定义字体极速体验,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近客户要求H5端使用Helvetica字体,由于对自定义字体之前不是很了解。
于是度娘了一下,发现Helvetica字体并不是随随便便就能使用的,如果系统本身就是使用的Helvetica 字体,那么font-family指定Helvetica 即可。
如果没有的话就要想办法把Helvetica 字体库文件导入到项目中来。

我们一般定义字体,是这样的:

body {font-family: tahoma, arial, 'Hiragino Sans GB', '\5b8b\4f53', sans-serif;
}

这是淘宝的字体设置,我们来分析一下

首先使用 tahoma 作为首选的西文字体,小字号下结构清晰端整、阅读辨识容易;
如果用户电脑未预装 tohoma,则选择 arial 作为替代的西文字体,覆盖 windows 和 MAC OS;
Hiragino Sans GB 为冬青黑体,首选的中文字体,保证了 MAC 用户的观看体验;
Windows 下没有预装冬青黑体,则使用 ‘\5b8b\4f53’ 宋体为替代的中文字体方案,小字号下有着不错的效果;
最后使用无衬线系列字体 sans-serif 结尾,保证旧版本操作系统用户能选中一款电脑预装的无衬线字体,向下兼容。

那么下面是我们自定义的字体:

@font-face {font-family: 'topWebfont';font-display: swap;src: url('ttf文件或者eto文件绝对路径'); 
}

如果想使用我们自定义的字体,那么只需要

  body {font-family: 'topWebfont', tahoma, arial, 'Hiragino Sans GB', '\5b8b\4f53', sans-serif;
}

把我们自定义字体的名称加入到第一位即可。
但是涉及到授权问题,如果你的项目是商用的,为了避免吃官司,不建议这样使用。
那么我们最好的解决方法是什么呢?
跟上面一样,优先使用Helvetica字体即可:

 body {font-family: Helvetica, tahoma, arial, 'Hiragino Sans GB', '\5b8b\4f53', sans-serif;
}

这样如果系统本身就有Helvetica字体,那么就会优先使用。

上面我们说了一种自定义字体的方式,把字体库下载下来,导入到项目中,代码中设置路径等等,是不是稍微有点麻烦呢?
这里再介绍一种方式,那就是阿里图标库在线字体
https://www.iconfont.cn/webfont?spm=a313x.7781069.1998910419.d81ec59f2#!/webfont/index

具体怎么使用呢,很简单

在这里插入图片描述

在这里插入图片描述
在页面中选择想用的开源字体库,复制对应字体库代码,这里推荐引用线上代码,到项目中即可。
需要注意的是:最上面的输入框中的内容,就代表了你要使用该字体库的中文,所以如果你想在项目中全部应用中文,那么只需要把项目中所有的中文复制到这里面,生成在线地址即可。

@font-face {font-family: 'webfont';font-display: swap;src: url('//at.alicdn.com/t/webfont_h2zl27npwtp.eot'); /* IE9*/src: url('//at.alicdn.com/t/webfont_h2zl27npwtp.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */url('//at.alicdn.com/t/webfont_h2zl27npwtp.woff2') format('woff2'),url('//at.alicdn.com/t/webfont_h2zl27npwtp.woff') format('woff'), /* chrome、firefox */url('//at.alicdn.com/t/webfont_h2zl27npwtp.ttf') format('truetype'), /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/url('//at.alicdn.com/t/webfont_h2zl27npwtp.svg#Alibaba-PuHuiTi-Regular') format('svg'); /* iOS 4.1- */
}body {font-family: 'webfont', tahoma, arial, 'Hiragino Sans GB', '\5b8b\4f53', sans-serif;
}

如果你的项目中的中文比较分散,没有单独在一个文件中,那么可以使用常用的汉字复制生成应该也可以满足需求,常用汉字大概有3500左右(常用3500中文)。

使用这种方式,是不是很简单呢?

在这里插入图片描述

这篇关于一行代码搞定,前端全局修改自定义字体极速体验的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1057478

相关文章

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim

jupyter代码块没有运行图标的解决方案

《jupyter代码块没有运行图标的解决方案》:本文主要介绍jupyter代码块没有运行图标的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录jupyter代码块没有运行图标的解决1.找到Jupyter notebook的系统配置文件2.这时候一般会搜索到