icon发展史速览

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- 0.2px;
  -moz-osx-font-smoothing: grayscale;
}
/* 使用unicode码 */

<i class="iconfont">&#xe604;</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 {
        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>
原文地址:https://www.cnblogs.com/sefaultment/p/11442745.html