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

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

最近客户要求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

相关文章

Python极速搭建局域网文件共享服务器完整指南

《Python极速搭建局域网文件共享服务器完整指南》在办公室或家庭局域网中快速共享文件时,许多人会选择第三方工具或云存储服务,但这些方案往往存在隐私泄露风险或需要复杂配置,下面我们就来看看如何使用Py... 目录一、android基础版:HTTP文件共享的魔法命令1. 一行代码启动HTTP服务器2. 关键参

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示