前端字体小记
使用自定义字体
使用CSS的font-face
语法如下
@font-face {
font-family: 'MyWebFont';
src: url('webfont.eot');
/* 兼容IE9 */
src: url('webfont.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
url('webfont.woff2') format('woff2'), /* 最新浏览器 */
url('webfont.woff') format('woff'), /* 较新浏览器 */
url('webfont.ttf')format('truetype'), /* Safari、Android、iOS */
url('webfont.svg#svgFontName') format('svg');
/* 早期iOS */
字体截取
中文字库很大,至少几MB十几MB。
网页所需的文字只是其中子集。
所以进行字体中截取部分所需文字即可。
确定所需文字 font-carrier: https://github.com/purplebamboo/font-carrier
适用情况:清楚需要渲染的文字,如上述需求只需要阿拉伯数字,一步到位。
- npm安装font-carrier
npm install font-carrier --save
- 新建index.js,将下列代码保存到本地
// 待抽取的字
var text = '0123456789';
// 引入font-carrier.js
var fontCarrier = require('font-carrier');
// 解析本地原来的字体文件
var transFont = fontCarrier.transfer('font/DIN Alternate Bold.ttf');
// font/DIN Alternate Bold.ttf替换成你的字体文件地址// 创建目标字体
var font = fontCarrier.create();
// 向字体中写入抽取的字形信息
font.setGlyph(transFont.getGlyph(text));
// 导出新字体到文件夹
// 默认会导出svg,ttf,eot,woff四种字体
// path结尾默认为导出新字体文件的名称
font.output({
path:'./fontMin' // 在当前路径导出fontMin.ttf等四种字体文件
});
// or
// font.output({
//path:'./fontMin/aaa' // 在当前路径的fontMin文件夹下导出aaa.ttf等四种字体文件
// });
- 运行index.js,得到精简的字体文件。
node index.js
- 使用字体
@font-face{
font-family: "your font name";
src: url("your font file url");
}.text{
font-family: "your font name";
}
此处介绍下@font-face的几个重要属性:
1)font-family不要用系统本身的字体名称如“Microsoft Yahei",会造成覆盖,很灾难,其他随意;
2)src中可以使用local(本地字体)和url(非跨域线上地址),提升体验;
3)font-weight可根据不同的字重加载不同字体,使字体视觉体验更加细腻;
4)unicode-range的作用是可以让特定的字符或者字符片段使用特定的字体。比如单独定义双引号使用的字体。
参考:https://mp.weixin.qq.com/s?src=https://www.it610.com/article/11×tamp=1541320153&ver=1223&signature=Cf2Ajfty3yoqvaBgfODUVtaLs4QvuwNTQq4FMX8Yfzmt1VdSAZJWIsPZY4QEFUA-U4mEVA0fNNQsFdcxjKzO8gPmzj6TP3IpkVXvJ-pKf8yiPugqwdCiCaqsqBX2&new=1
需要扫描html/css/js文件中使用到的汉字 【前端字体小记】使用字蛛FontSpider
推荐阅读
- 私通和背叛,他怎么看(——晨读小记)
- 日更小小记
- Jsr303做前端数据校验
- 7、前端--jQuery简介、基本选择器、基本筛选器、属性选择器、表单选择器、筛选器方法、节点操作、绑定事件
- 前端代码|前端代码 返回顶部 backToTop
- 巴塞罗那之旅小记(二)---|巴塞罗那之旅小记(二)--- 上帝之手的杰作圣家堂
- iOS富文本为html时,修改默认字体颜色
- 前端|web前端dya07--ES6高级语法的转化&render&vue与webpack&export
- 前端自学笔记01
- js保留自定义小数点