icon
发展史
img
多张图片占用多个请求,想办法减少请求,合并图片,image sprite
background-position
/* 使用background-position来定位图标 */
缺点
1.新增图片就要改动雪碧图,不小心会影响到其他图片,导致已经写好的定位显示出错
字体库
本质是引入了一个字体文件,然后在对应位置使用unicode就可以显示该图表
unicode
优点
1.兼容IE6+
2.支持按照字体的方式去动态调整图标的大小、颜色
缺点
1.不支持多色图标
2.在不同的设备浏览器字体的渲染会略有差别,在不同的浏览器或系统中对文字的渲染不同,其显示的位置和大小可能会受到font-size、line-height、word-spacing等CSS属性的影响,而且这种影响调整起来较为困难
3.语义非常弱,光看unicode码,不知道它是什么
使用方式
/* 引入font-face自定义字体 */
@font-face {
font-family: "iconfont";
src: url('iconfont.eot'); /* IE9*/
src: url('iconfont.eot#iefix') format('embedded-opentype'), /* IE6-IE8 */
url('iconfont.woff') format('woff'), /* chrome, firefox */
url('iconfont.ttf') format('truetype'), /* chrome, firefox, opera, Safari, Android, iOS 4.2+*/
url('iconfont.svg#iconfont') format('svg'); /* iOS 4.1- */
}
/* 定义iconfont通用类 */
.iconfont {
font-family:"iconfont" !important;
font-size:16px;
font-style:normal;
-webkit-font-smoothing: antialiased;
-webkit-text-stroke-width: 0.2px;
-moz-osx-font-smoothing: grayscale;
}
/* 使用unicode码 */
<i class="iconfont"></i>
font-class
相比unicode方式,优点就是语义更加明确,可以看见class就知道它是什么图标
使用方式
// 引入font-class文件
../font_8d5l8fzk5b87iudi.css
找到对应图标类名并使用
<i class="iconfont icon-xxx"></i>
symbol
优点
1.支持多色图标
2.可以使用CSS实现动画,不需要再使用gif
3.矢量,缩放不失真,再也不用按照不同分辨率设置不用的图标了
4.本身就是DOM规范的一部分,可以像普通DOM一样修改颜色,交互性非常强
使用方式
第一步:拷贝项目下面生成的symbol代码:
引入 ./iconfont.js
复制代码第二步:加入通用css代码(引入一次就行):
<style type="text/css">
.icon {
width: 1em; height: 1em;
vertical-align: -0.15em;
fill: currentColor;
overflow: hidden;
}
</style>
复制代码第三步:挑选相应图标并获取类名,应用于页面:
<svg class="icon" aria-hidden="true">
<use xlink:href="#icon-xxx"></use>
</svg>