今天模仿百度首页手机版的时候遇到的@font-face的问题,如今整理一下。css
问题:图中红色区域,在拷贝F12样式的时候,并无出现这些小图标。chrome
图1:百度的效果 图2:我作的效果浏览器
在审查元素的时候,发现这些地方不是图片,只是字体。代码以下:svg
.navs-news:before { content: "\e672"; color: #777; font: 24px/1 icons; }
@font-face { /*自定义的字体名称*/ font-family: <YourWebFontName>; /*source是自定义的字体的存放路径 format是自定义的字体的格式,主要用来帮助浏览器识别*/ src: <source> [<format>][,<source> [<format>]]*; /*字体是否为粗体*/ font-weight: <weight>; /*定义字体样式*/ font-style: <style>; }
@font-face{ font-family:icons; src:url(//m.baidu.com/static/index/iconfont/iconfont_f0abbec7.eot); src:url(//m.baidu.com/static/index/iconfont/iconfont_f0abbec7.eot#iefix) format('embedded-opentype'), url(//m.baidu.com/static/index/iconfont/iconfont_f0abbec7.woff) format('woff'), url(//m.baidu.com/static/index/iconfont/iconfont_f0abbec7.ttf) format('truetype'), url(//m.baidu.com/static/index/iconfont/iconfont_f0abbec7.svg?#iconfont) format('svg'); font-weight:400; font-style:normal }
@font-face { font-family: icons; src: url(../fonts/iconfont_f0abbec7.eot); src: url(../fonts/iconfont_f0abbec7.eot#iefix) format('embedded-opentype'), url(../fonts/iconfont_f0abbec7.woff) format('woff'),
url(../fonts/iconfont_f0abbec7.ttf) format('truetype'),
url(../fonts/iconfont_f0abbec7.svg?#iconfont) format('svg'); font-weight: 400; font-style: normal }
这时候,回到咱们最开始看到的代码就能够解释了,如代码里的注释:字体
.navs-news:before { /*字体图标的编号*/ content: "\e672"; /*字体颜色*/ color: #777; /*字体大小,以及font-family:icons和@font-face呼应*/ font: 24px/1 icons; }
再刷新咱们的网页,便可看到这些可爱的“小图标”。url
全部的字体文件最好都下载到本地,由于各个浏览器支持的字体不一致。好比.eot字体是IE专用字体,能够从TrueType建立此格式字体,支持这种字体的浏览器有【IE4+】;.svg字体是基于SVG字体渲染的一种格式,支持这种字体的浏览器有【Chrome4+,Safari3.1+,Opera10.0+,iOS Mobile Safari3.2+】spa