经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTMLCSS » CSS » 查看文章
CSS 小结笔记之图标字体(IconFont)
来源:cnblogs  作者:Assist  时间:2018/10/8 8:47:08  对本文有异议

  本篇主要介绍一种非常好用的图标大法——图标字体(IconFont)。

  什么是图标字体?顾名思义,它是一种字体,只不过这个字体显示的并不是具体的文字之类的,而是各种图标。

  网站上经常会用到各种图标,之前网页上使用图标主要采用精灵图(背景位置+背景缩放)来实现,但是这样使用起来有许多不便之处,一方面缩放处理起来比较麻烦,一方面如果要改动一些图标就需要去找到设计人员重新设计,然后重新添加,这个过程非常不友好。

  图标字体可以非常便捷的去解决以上问题,使用起来也非常简单。因为他是字体,所以可以当成字体来引用,只需要给出对应的字符而不需要通过测量背景图片位置那么麻烦。并且改变图标大小只需要改变字体大小就可以了。这里有两个网站推荐:(1)、阿里巴巴矢量图标库http://iconfont.cn/ (2)IcoMoon https://icomoon.io/  

  下面给出IcoMoon 具体使用方法

  1、打开IcoMoon 网站,点击IconMoon App

  

  2、打开后是具体图标的界面,可以自己添加自己的图标进行生成,也可以选用他给出的图标,在默认图标的下方 会有add Icons From Library 点击后可以看到更多的图标供选择(有免费的有付费的)。

  

  3、点击Generate Font后会生成 当前选择的图标的界面,右下角的Generate Font 也会变成 Download ,也可以进行相关的下载设置(例如:让其支持ie6/7之类的)。

  4、下载完成后 会有以下文件,这些文件都最好保存下来,不要随意删掉。

    

  5、接下来给出图标字体的具体使用方法(也可以自行看使用图标字体的css文件——style.css的相关内容)

    (1)、将字体文件夹复制到项目中并且声明字体(此处代码不需要记忆,因为基本上都一样,直接复制即可)   

  1. @font-face {
  2. font-family: 'icomoon';/*声明字体名称,可自行设置,应用的时候对应即可*/
  3. src: url('fonts/icomoon.eot?lep7lm');
  4. src: url('fonts/icomoon.eot?lep7lm#iefix') format('embedded-opentype'),
  5. url('fonts/icomoon.ttf?lep7lm') format('truetype'),
  6. url('fonts/icomoon.woff?lep7lm') format('woff'),
  7. url('fonts/icomoon.svg?lep7lm#icomoon') format('svg');
  8. font-weight: normal;
  9. font-style: normal;
  10. }

    (2)、使用字体    

  1. .IconMoon {
  2. font-family: 'icomoon';
  3. }

    (3)、具体显示对应图标

      a、直接使用(很方便,但是一般不要使用,因为光看小方块分辨不出这些图标有什么区别), 例如

  1.       <li><span class="iconhome">?</span></li>
  2. <li><span class="iconsmile">?</span></li>
  3. <li><span class="icontongue">?</span></li>

      span标签中间的小方块不是真的方块,而是对应Demo页面中每个图标下面对应右侧的方块。

      

      b、使用css 伪元素选择器before 来进行添加

  1. <li><span class="icon-home">在这前面有一个home图标</span></li>
  2. <li><span class="icon-smile2">在这前面有一个smile2图标</span></li>
  3. <li><span class="icon-tongue2">在这前面有一个tongue2图标</span></li>
  4. <li><span class="icon-sad2">在这前面有一个sad2图标</span></li>
  5. <li><span class="icon-wink">在这前面有一个wink图标</span></li>

      对应的css代码为     

  1. .icon-home:before {/*content的值是对应的图标代码*/
  2. content: "\e900";
  3. }
  4. .icon-smile2:before {
  5. content: "\e9e2";
  6. }
  7. .icon-tongue2:before {
  8. content: "\e9e4";
  9. }
  10. .icon-sad2:before {
  11. content: "\e9e6";
  12. }
  13. .icon-wink:before {
  14. content: "\e9e7";
  15. }

       效果图为

        

    (4)、正如之前所说,这些图标本质上是字体,所以可以很方便的去改变颜色,大小,产生阴影效果等

        

具体的代码如下

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. Ul {
  11. list-style: none;
  12. }
  13. @font-face {
  14. font-family: 'icomoon';
  15. /*声明字体名称,可自行设置,应用的时候标出即可*/
  16. src: url('fonts/icomoon.eot?lep7lm');
  17. src: url('fonts/icomoon.eot?lep7lm#iefix') format('embedded-opentype'), url('fonts/icomoon.ttf?lep7lm') format('truetype'), url('fonts/icomoon.woff?lep7lm') format('woff'), url('fonts/icomoon.svg?lep7lm#icomoon') format('svg');
  18. font-weight: normal;
  19. font-style: normal;
  20. }
  21. .IconMoon {
  22. font-family: 'icomoon';
  23. }
  24. .icon-home:before {
  25. /*content的值是对应的图标代码*/
  26. content: "\e900";
  27. color: aqua;
  28. font-size: 20px;
  29. }
  30. .icon-smile2:before {
  31. color: deeppink;
  32. font-size: 40px;
  33. content: "\e9e2";
  34. }
  35. .icon-tongue2:before {
  36. color: orange;
  37. font-size: 10px;
  38. content: "\e9e4";
  39. }
  40. .icon-sad2:before {
  41. content: "\e9e6";
  42. text-shadow: 0 2px 2px rgba(0, 0, 0, 0.4);
  43. color: blue;
  44. font-size: 40px;
  45. }
  46. .icon-wink:before {
  47. content: "\e9e7";
  48. text-shadow: 4px 4px 4px rgba(0, 0, 0, 0.4);
  49. color: blue;
  50. font-size: 40px;
  51. }
  52. </style>
  53. </head>
  54.  
  55. <body>
  56. <div class="IconMoon">
  57. <ul>
  58.  
  59. <li><span class="icon-home">在这前面有一个home图标</span></li>
  60. <li><span class="icon-smile2">在这前面有一个smile2图标</span></li>
  61. <li><span class="icon-tongue2">在这前面有一个tongue2图标</span></li>
  62. <li><span class="icon-sad2">在这前面有一个sad2图标</span></li>
  63. <li><span class="icon-wink">在这前面有一个wink图标</span></li>
  64. </ul>
  65. </div>
  66. </body>
  67.  
  68. </html>
View Code

  6、当我们想要给字体添加新的图标或者减去一些图标时,只需再次打开网站,进入到IconMoon App 页面,然后点击 Import Icons 将之前我们下载的字体文件目录下的selection.json 文件,就可以在我们之前选中的基础上再次进行操作了,用起来非常的方便。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号