zoukankan      html  css  js  c++  java
  • 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>
    
  • 相关阅读:
    很简单的在Ubuntu系统下安装字体和切换默认字体的方法
    Qt添加驱动——Qt数据库之添加MySQL驱动插件
    qt 字体的相关问题
    qt configure参数配置介绍
    Qt封装QTcpServer参考资料--QT4中构建多线程的服务器
    Qt封装QTcpServer参考资料--QTcpServer多线程实现
    Qt封装QTcpServer参考资料--QT自带QTcpServer架构分析
    Qt Creator设置多核编译(-j8参数)
    QString::​arg的用法
    《Qt数据类型》--QByteArray,QString,int,hex之间的转化
  • 原文地址:https://www.cnblogs.com/sefaultment/p/11442745.html
Copyright © 2011-2022 走看看