美文网首页
啊,这连字体都要减肥的世道啊

啊,这连字体都要减肥的世道啊

作者: Apollozz | 来源:发表于2018-10-29 16:13 被阅读0次

    菠萝:“大佬,你这几个数字一定要用这个字体吗?雅黑苹方不可以吗?”
    设计师大佬一脸委屈地看着菠萝:“可是这个字体好看啊。”
    表情如下:


    哎没办法,这眼神分分钟让人觉得自己在犯罪。那就只能搞个font-face了,可是就10个阿拉伯数字要77K,这这这!不行不行,减下肥。

    菠萝推荐:

    font-carrier: https://github.com/purplebamboo/font-carrier

    适用情况:清楚需要渲染的文字,如上述需求只需要阿拉伯数字,一步到位。

    1. npm安装font-carrier
    npm install font-carrier --save
    
    1. 新建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等四种字体文件
    // });
    
    1. 运行index.js,得到精简的字体文件。
    node index.js
    
    1. 使用字体
    @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://www.zhangxinxu.com/wordpress/2017/03/css3-font-face-src-local/

    小结:


    1. 虽然这次用的字体文件是个英文字体包,体积不算大,但是77K到3K的变化还是很可观的,对字体有兴趣的,可以使用wakamaifondue对字体文件进行分析。
    2. font-carrier对于已知使用文字的字体文件精简还是很便捷的,而且因为当前数据是通过接口获取,使用扫描工具并不适用。
    3. 如果是需要扫描html/css/js文件中使用到的汉字(因为中文字体文件比较大,需求一般针对汉字字体文件进行压缩)则不适合使用font-carrier,可以考虑了解下字蛛FontSpider

    相关文章

      网友评论

          本文标题:啊,这连字体都要减肥的世道啊

          本文链接:https://www.haomeiwen.com/subject/gtpbtqtx.html