字蛛是一个智能 WebFont 压缩工具,它能自动分析出页面使用的 WebFont 并进行按需压缩。
- 压缩字体:智能删除没有被使用的字形数据,大幅度减少字体体积
- 生成字体:支持 woff2、woff、eot、svg 字体格式生成
New: 字蛛 v1.0.0 版本支持图标字体!更新日志
安装好 nodejs,然后执行:
npm install font-spider -g
/*声明 WebFont*/
@font-face {
font-family: 'source';
src: url('../font/source.eot');
src:
url('../font/source.eot?#font-spider') format('embedded-opentype'),
url('../font/source.woff2') format('woff2'),
url('../font/source.woff') format('woff'),
url('../font/source.ttf') format('truetype'),
url('../font/source.svg') format('svg');
font-weight: normal;
font-style: normal;
}
/*使用指定字体*/
.home h1, .demo > .test {
font-family: 'source';
}
特别说明:
@font-face
中的src
定义的 .ttf 文件必须存在,其余的格式将由工具自动生成
font-spider [options] <htmlFile1 htmlFile2 ...>
一个或多个页面地址,支持 http 形式。
例如:
font-spider dest/news.html dest/index.html dest/about.html
-h, --help 输出帮助信息
-V, --version 输出当前版本号
--info 输出 WebFont 的 JSON 描述信息,不压缩与转码
--ignore <pattern> 忽略的文件配置(支持正则表达式)
--map <remotePath,localPath> 映射 CSS 内部 HTTP 路径到本地(支持正则表达式)
--no-backup 关闭字体备份功能
--debug 调试模式,打开它可以显示 CSS 解析错误
使用通配符压缩多个 HTML 文件关联的 WebFont:
font-spider dest/*.html
--info
查看网站所应用的 WebFont:
font-spider --info http://fontawesome.io
--ignore
忽略文件:
font-spider --ignore "icon\\.css$" dest/*.html
--map
参数将线上的页面的 WebFont 映射到本地来进行压缩(本地路径必须使用绝对路径):
font-spider --map "http://font-spider.org/font,/Website/font" http://font-spider.org/index.html
font-spider 包括爬虫与压缩器模块,接口文档:API.md
- 不支持 javascript 动态插入的元素与样式
- .otf 字体需要转换成 .ttf 格式才能被压缩(免费 ttf 字体资源)
- 仅支持
utf-8
编码的 HTML 与 CSS 文件 - CSS
content
仅支持content: 'prefix'
和content: attr(value)
这两种形式
格式 | IE | Edge | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Chrome for Android |
---|---|---|---|---|---|---|---|---|---|
.eot |
6 | -- | -- | -- | -- | -- | -- | -- | -- |
.woff |
9 | 13 | 3.6 | 5 | 5.1 | 11.1 | 5.1 | 4.4 | 36 |
.woff2 |
-- | 14 | 39 | 36 | -- | 23 | -- | 50 | 50 |
.ttf |
-- | 13 | 3.5 | 4 | 3.1 | 10.1 | 4.3 | 2.2 | 36 |
.svg |
-- | -- | -- | 4 | 3.2 | 9.6 | 3.2 | 3 | 36 |