如果你对iconfont有所了解,那你一定对这次iconfont做出的更新产生兴趣。没错,iconfont目前已经升级为iconfont+,并且能够支持大家都很期待的彩色图标。 之前,大家也以文字的形式实现过网页中的图标和特殊字符,现在,使用全新的彩色图标一定更能体现

symbol引用: 这是一种全新的使用方式,应该说这才是未来的主流,也是平台目前推荐的用法。相关介绍可以参考这篇文章 这种用法其实是做了一个svg的集合,与另外两种相比具有如下特点: 支持多色图标了,不再受单色限制。 通过一些技巧,支持像字体那样,通过font-size,color来调整样式。 兼容性较差,支持 ie9+,及现代浏览器。 浏览器渲染svg的性能一般,还不如png。 这种全新的使用方式,据官网介绍说是做了一个svg的集合,SVG(Scalable Vector Graphics)可缩放矢量图形,SVG具有什么特点呢? SVG特点: 1.任意放缩。(用户可以任意缩放图像显示,而不会破坏图像的清晰度、细节等。) 2.文本独立。(SVG图像中的文字独立于图像,文字保留可编辑和可搜寻的状态。也不会再有字体的限制,用户系统即使没有安装某一字体,也会看到和他们制作时完全相同的画面。) 3.较小文件。(总体来讲,SVG文件比那些GIF和JPEG格式的文件要小很多,因而下载也很快。) 4.超强显示效果。(SVG图像在屏幕上总是边缘清晰,它的清晰度适合任何屏幕分辨率和打印分辨率。) 5.超级颜色控制。(SVG图像提供一个1 600万种颜色的调色板,支持ICC颜色描述文件标准、RGB、线X填充、渐变和蒙版。) 由于svg的格式优点是基于xml可扩展标记语言,是一个XML文件,而且SVG是被设计用于互联网,所以通过Javascript和DOM访问它就是最重要的应用模式。通过Javascript和DOM可以动态地修改HTML,同样也可以在浏览器中动态地创建、修改和删除图片。 因此在网页中使用svg与其他图像格式相比(比如 JPEG 和 GIF)的优势在于: SVG 图像可通过文本编辑器来创建和修改 SVG 图像可被搜索、索引、脚本化或压缩 SVG 是可伸缩的 SVG 图像可在任何的分辨率下被高质量地打印 SVG 可在图像质量不下降的情况下被放大 而浏览器的支持情况,iconfont官网也有说明: Internet Explorer 9、Firefox、Opera、Chrome 以及 Safari 支持内联 SVG。Internet Explorer 8或更早版本,可通过安装Adobe SVG Viewer以支持SVG。 iconfont官网描述浏览器渲染svg的性能一般,还不如png,实测了一下做了几个彩色小icon,现代浏览器对svg渲染其实也相当不错了。而且iconfont平台也是推荐这种全新的使用方式,现在互联网技术迅猛发展,相信不久的将来这种使用方式会是未来的主流。 介绍了那么多,那么来做个小案例体验一下。 首先还是到iconfont官网,这次找几个彩色的图标:

网页导航栏多色图标库,点进去会发现很多多色图标库的集合:

找到对应的图标保存到项目后,去图标管理—我的项目里面,找到新添加的项目并下载到本地,下载下来解压后我们可以看到这些文件:

iconfont+除了全新的使用方式,传统的使用方式也进行了一些优化,详细可以参考demo文件: 首先第一个demo文件打开是font-class引用 font-class是unicode使用方式的一种变种,主要是解决unicode书写不直观,语意不明确的问题。 与unicode使用方式相比,具有如下特点: 兼容性良好,支持ie8+,及所有现代浏览器。 相比于unicode语意明确,书写更直观。可以很容易分辨这个icon是什么。 因为使用class来定义图标,所以当要替换图标时,只需要修改class里面的unicode引用。 不过因为本质上还是使用的字体,所以多色图标还是不支持的。 使用步骤如下: (注意:为了浏览器更好的渲染,如果只使用单色图标,建议不要选择下载多色图标替代)

第一步:引入项目下面生成的fontclass代码:

(这种方式是需要引入iconfont.css文件,同时还需要注意字体文件的摆放路径) 第二步:挑选相应图标并获取类名,应用于页面:实际情况中"iconfont"(font-family)需要修改为你项目下的font-family。可以通过编辑项目查看,默认是"iconfont"。 iconfont.css源码其实也是通过@font-face规则声明字体,并引用字体文件,而字体编码则是通过伪元素的方法添加进html标签里面的,所以对于浏览器支持情况需要ie8+(下图为添加字体编码css样式) ![image05](https://img-blog.csdnimg.cn/20191206133752666.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3p6YzE5OTgxMjIx,size_16,color_FFFFFF,t_70) 这种使用方式需要注意的地方也都提过了,有兴趣的可以去亲自体验一下。 最原始的的unicode使用方式的使用方法可参考上一个教程,教程链接:http://bbs.520it.com/forum.php?mod=viewthread&tid=1950 现在来看一下全新的使用方式,symbol引用,其实这种方式使用起来也非常简单。打开demo_symbol.html文件可以看到详细的使用方法: iconfont图标分别对应不同的类名:

symbol引用: 使用步骤如下: 第一步:引入项目下面生成的symbol代码:

(首先需要引入iconfont.js文件,此js文件相当于是svg图形集合文件的调用) 第二步:加入通用css代码(引入一次就行)

第三步:挑选相应图标并获取类名,应用于页面:实际情况中"iconfont"(font-family)需要修改为你项目下的font-family。可以通过编辑项目查看,默认是"iconfont"。 使用多色图标引用效果:

可以看出浏览器渲染还是非常不错,关于iconfont的其他更多操作,还需要大家继续探索,并结合实际完成操作。

最新文章

  1. 基本排序算法——选择排序java实现
  2. 16进制ascii码转化为对应的字符,付ipmitool查询硬件信息
  3. Android开发总是难以入门
  4. Vue.2.0.5-计算属性
  5. yii中设置提示成功信息,错误提示信息,警告信息
  6. android中broadcastreceiver的用法-manifest中注册。
  7. 初试集群虚拟化搭建(二)—— Xen, kvm, OpenStack, VMware ESXi, Citrix XenServer等种种选择
  8. 支付宝开通海外退税 阿里腾讯暗战跨境O2O_21世纪网
  9. TIDB 参数解释
  10. My Function Lib
  11. LCD显示GPS时钟[嵌入式系统]
  12. linux下JAVA开发的环境配置
  13. CSS优先级的及其衡量标准CSS权重
  14. 由JDBC而来的对Class.forName()用法发散
  15. circRNA 中的ALU 重复元件
  16. 04-01 Java switch、for、while、do while语句,循环嵌套,跳转语句break、continue、return
  17. 全网最详细的启动Kafka服务时出现kafka.common.InconsistentBrokerIdException: Configured brokerId 3 doesn't match stored brokerId 1 in meta.properties错误的解决办法(图文详解)
  18. 使用array_merge重新排列数组下标
  19. 使用 intellij idea 进行远程调试
  20. java基础55 UDP通讯协议和TCP通讯协议

热门文章

  1. BZOJ 4571: [Scoi2016]美味
  2. Mac laravel: command not found
  3. [loj 6496]「雅礼集训 2018 Day1」仙人掌
  4. Control.ImeMode属性简释
  5. 三大框架 之 Spring(IOC控制反转、DI依赖注入)
  6. win10 eclipse连接虚拟机ubuntu中的hdfs
  7. html5中的fieldset/legend元素和keygen元素
  8. Unity3D 2D模拟经营游戏 洗车沙龙 完整源码
  9. 关于如何取消访问https时的提示:“此网站的安全证书存在问题”的解决方法
  10. IM 简介