菠萝:“大佬,你这几个数字必定要用这个字体吗?雅黑or苹方不能够吗?”css
设计师大佬一脸委屈地看着菠萝:“但是这个字体好看啊。”html
表情以下:node
哎没办法,这眼神分分钟让人以为本身在犯罪。那就只能搞个font-face了,但是就10个阿拉伯数字要77K,这这这!不行不行,减下肥。css3
font-carrier:github.com/purplebambo…
适用状况:清楚须要渲染的文字,如上述需求只须要阿拉伯数字,一步到位。git
npm install font-carrier --save
复制代码
// 待抽取的字
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等四种字体文件
// });
复制代码
node index.js
复制代码
@font-face{
font-family: "your font name";
src: url("your font file url");
}
.text{
font-family: "your font name";
}
复制代码
font-family
不要用系统自己的字体名称如“Microsoft Yahei",会形成覆盖,很灾难,其余随意;src
中可使用local(本地字体)和url(非跨域线上地址),提高体验;font-weight
可根据不一样的字重加载不一样字体,使字体视觉体验更加细腻;unicode-range
的做用是可让特定的字符或者字符片断使用特定的字体。好比单独定义双引号使用的字体。此处推荐张大神的文章:真正了解CSS3背景下的@font face规则github