在网页中使用 icon 字体图标 | 前端开发

简介: 在网页中使用 icon 字体图标 | 前端开发

最近在 B 站上看 Pink 老师的前端视频,简单总结一下在网页中使用 icon 图标的两种方法。

直接插入字体图标

这里说的字体图标,是指既有普通 icon 图标的外观,又带有字体特征的图标,可以像调整字体那样、调整图标的大小和颜色,且图标放大之后不会失真变模糊。

我们一般是从网上下载字体图标的,譬如国内的阿里巴巴旗下的矢量素材网站 iconfont、国外的 IcoMoon 等。

去年写过一篇文章《微信小程序开发 | 如何在小程序中使用自定义 icon 图标》,其中介绍了 iconfont 图标的使用,这回介绍一下使用来自 IcoMoon 的图标的方法。

打开 IcoMoon 图标官网,从中挑选你想使用的 icon 图标,底部的 Selection 会统计你选中的图标数量,选好图标之后,点击右下角的 Generate Font,生成字体图标。

ff14a539033d861eb82caa74db8ffdc3_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

在打开的页面,会显示我们刚才挑选的所有 icon 图标,并且提供图标的 unicode 编码,这些编码等下要用到,但现在先不管。点击右下角的 Download,下载生成的字体图标文件。

16c319bd2dac9159d7a2416c4541f464_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

IcoMoon 图标下载:

https://icomoon.io/app/#/select

解压下载的压缩文件,其中包含下面这些文件,我们需要用到其中的 fonts 文件夹。

f72696eb200db19730694064b4f90a27_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

fonts 文件中包含了 4 个字体文件,这是因为不同浏览器所支持的字体格式是不一样的,考虑到兼容性,fonts 文件夹就包含了主流浏览器支持的字体文件:

  • TrueType 字体(.ttf):是 Windows 和 Mac 最常见的字体
  • Web Open Font Format 字体(.woff):支持的浏览器有 IE 9+、Firefox 3.5+、Chrome 6+、Safari 3.6+、Opera 11.1+
  • Embedded Open Type 字体(.eot):是 IE 专用的字体,支持的浏览器有 IE 4+    
  • SVG 字体(.svg):是基于 SVG 字体渲染的一种格式,支持的浏览器有 Chrome 4+、Safari 3.1+、Opera 10.0+、iOS Mobile Safari 3.2+

6efed80524f6bbce9c52e83d021fd5d7_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

将 fonts 文件夹复制到网页的项目文件夹📂中,譬如放在与  index.html 文件同级的路径下。

打开 HTML 文件,在 style 标签中粘贴下方的代码,定义我们等下需要用到的字体 icomoon。需要注意的是,如果 fonts 文件与 html 文件在同个路径下,就不需要修改下方代码中的 url 地址。

<style>
  @font-face {
              font-family: 'icomoon';
              src: url('fonts/icomoon.eot?bawtoo');
              src: url('fonts/icomoon.eot?bawtoo#iefix') format('embedded-opentype'),
                  url('fonts/icomoon.ttf?bawtoo') format('truetype'),
                  url('fonts/icomoon.woff?bawtoo') format('woff'),
                  url('fonts/icomoon.svg?bawtoo#icomoon') format('svg');
              font-weight: normal;
              font-style: normal;    
              font-display: block;
          }
</style>

粘贴代码之后,先来看一下我们最终想要实现的效果,如下图,下方的红色爱心❤️图标,就是前面说到的字体图标。根据最终想要实现的效果,我们要去到 html 文件中书写相应的代码。

f50143360b77c1c3916c905642a8d0b0_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

在 html 文件的 body 标签中输入下方的一行代码,中间的 span 标签包含的方块,其实就是爱心图标,只不过它无法在 html 文件中正常显示。


<p>我 <span></span> 你</p>

这个方块也不是随意输入的,还得从我们前面下载的压缩文件夹中的 demo.html 查看。

272742f57c9a6834d569946690e00ef1_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

在浏览器中打开 demo.html ,移动到爱心图标右下角的区域,框选有时看得到、有时看不到的方块字符,复制到剪贴板,接着粘贴到 html 文件中。

fdc51df8a2bde3d162b4879dcc89b4b5_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

将方块字符粘贴到 html 中,如果此时在浏览器中预览网页效果的话,还是无法看到刚添加的字体图标的,因为还缺少对字体图标设置 CSS 样式——声明字体图标所使用的字体

html:

<p>
  我<span></span>你
</p>

css:

p span {        
    font-family: 'icomoon';
}

此时在浏览器中重新打开 html 文件,我们所使用的字体图标就会正常显示了。

如果你还想调整字体图标的大小颜色,可以在 CSS 中增加另外两个属性:font-sizecolor

css:

p span {      
    font-family: 'icomoon';      
    font-size: 50px;      
    color: red;
}

一番设置之后,重新在浏览器中刷新页面,就可以看到最终的效果啦。

通过伪类选择器使用字体图标

前面介绍的第一种方法,需要同时在 body 标签(html) 和 style 标签(css) 中同时书写相关的代码,如果我们想让 html 文件的结构更加简单,我们可以通过第二种方法——在  style 标签(css) 中通过伪类选择器使用字体图标,这样就只需要在 style 标签或 css 文件中书写相关的代码。

先来看一下我们最终想要实现的效果,如下图所示,给输入框的右侧添加一个向下的小三角🔽图标

558eec87a6fd8ee3617e12960ff7001a_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

想制作这个效果,同样是先从前面介绍的 IcoMoon 网站下载字体图标,将解压后的文件中的 fonts 文件夹放到与 index.html 同级的路径下,接着在 html 的 style 标签中粘贴下方的代码:

<style>
  @font-face {
              font-family: 'icomoon';
              src: url('fonts/icomoon.eot?bawtoo');
              src: url('fonts/icomoon.eot?bawtoo#iefix') format('embedded-opentype'),
                  url('fonts/icomoon.ttf?bawtoo') format('truetype'),
                  url('fonts/icomoon.woff?bawtoo') format('woff'),
                  url('fonts/icomoon.svg?bawtoo#icomoon') format('svg');
              font-weight: normal;
              font-style: normal;    
              font-display: block;
          }
</style>

在 html 的 body 标签中插入一个空白的盒子 div 标签:

<body>
  <div></div>
</body>

接着在 style 标签中,给 div 盒子设置宽度、高度,并给它设置一个粗细为 1 px 的黑色边框:

<style>
  div {    
    width: 200px;    
    height: 40px;    
    border: 1px solid gray;
}
</style>

此时在浏览器中打开 html 文件,就可以看到下图所示的孤零零的输入框。

8bc616eadfbd7054bf628190f246973a_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

接着继续给这个输入框「添砖加瓦」——添加一个向下的小三角🔽,继续在 style 标签中书写代码:

div::after {
    content: '';
    font-family: 'icomoon';
}

稍微解释一下这个代码,在 div 后面加上两个英文中的冒号,并且跟上单词 after 或者 before,就是所谓的伪类选择器,在我目前的认知范围内,伪类选择器就是用 css 代码来给 html 页面添加额外的元素,我们也确实可以在网页中看到添加的小三角,如下图。但这段代码是写在 css 而非 html 文件中,一定程度上可以简化 html 文件的代码。

625f39c2baf0302b5b7377299201ec23_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

到这里,我们就顺利地在 html 页面中添加了字体图标,值得一提的是,伪类选择器中 content 属性的值,除了可以是字体图标对应的方块字符,还可以是字体图标下方的编号

以下图为例,爱心图标的编号是 e9da,因此 content 属性的值也可以是 \e9da ,通过编号来调用字体图标的时候,需要在编号的最前面加多一个反斜杆 \ 。

div::after {
    content: '\e9da';
    font-family: 'icomoon';
}

a3ab9f3402dfe5211c2f886bbd63ee6f_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

引入字体图标之后,字体图标默认位于输入框的左上角,为了将字体图标移动到右侧居中的位置,这里还需要用到另外的知识——定位,包含相对定位绝对定位

625f39c2baf0302b5b7377299201ec23_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

关于定位的知识,这里暂时就不过多展开了,可以记住一个口诀「子绝父相」,即子元素设置绝对定位,父元素设置相对定位,就可以达到自由移动下拉小三角位置的目的。

分别给 div 和伪元素选择器 div::after 添加另外的样式:

div {
    position: relative;
}
div::after {
    position: absolute;
    top: 12px;
    right: 10px;
}

这里的 top 和 right 属性的值,并不是唯一的,需要根据实际情况,配合浏览器的开发者工具进行调整,最终得到看起来比较舒适的值(主要就是调整到小三角可以位于输入框水平居中的位置),最终效果如下。

558eec87a6fd8ee3617e12960ff7001a_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

以上,就是本次想和你分享的内容。


相关文章
|
26天前
|
前端开发 JavaScript API
(前端3D模型开发)网页三维CAD中加载和保存STEP模型
本文介绍了如何使用`mxcad3d`库在网页上实现STEP格式三维模型的导入与导出。首先,通过官方教程搭建基本项目环境,了解核心对象如MxCAD3DObject、Mx3dDbDocument等的使用方法。接着,编写了加载和保存STEP模型的具体代码,包括HTML界面设计和TypeScript逻辑实现。最后,通过运行项目验证功能,展示了从模型加载到保存的全过程。此外,`mxcad3d`还支持多种其他格式的三维模型文件操作。
|
2月前
|
XML 前端开发 JavaScript
前端大神揭秘:如何让你的网页秒变炫酷,让用户欲罢不能的5大绝招!
前端开发不仅是技术活,更是艺术创作。本文揭秘五大前端开发技巧,包括合理运用CSS动画、SVG图形、现代JavaScript框架、优化网页性能及注重细节设计,助你打造炫酷网页,提升用户体验。
86 30
|
2月前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
59 5
|
2月前
|
存储 编解码 前端开发
惊!前端新手也能秒懂的高级技巧,轻松提升网页颜值与性能!
本文针对前端新手,介绍了三个简单易学的高级技巧,帮助提升网页的颜值和性能。包括使用CSS框架快速美化网页、优化图片资源加快加载速度,以及利用ARIA属性和媒体查询提高网页的可访问性和响应性。示例代码清晰,适合初学者上手实践。
44 3
|
2月前
|
存储 前端开发 搜索推荐
(前端直接编辑CAD)网页CAD二次开发中线型表的使用方法
在DWG数据库中,线型样式存储在线型样式表 `McDbLinetypeTable` 中,每个线型表记录对象 `McDbLinetypeTableRecord` 对应一种线型样式。本文介绍了如何获取、添加、遍历、删除和修改线型样式,并提供了绘制不同线型的示例代码,包括虚线、点划线和带文字的线型。通过在线示例demo,用户可以实践修改CAD图纸中的实体线型及其样式。
|
2月前
|
搜索推荐 前端开发 开发者
前端开发的必修课:如何让你的网页在搜索引擎中脱颖而出?
【10月更文挑战第31天】前端开发不仅是构建网页与用户间桥梁的关键,还需注重搜索引擎优化(SEO)。优化网页结构、合理使用关键词、提升加载速度及整合社交媒体等技巧,能帮助网页在搜索引擎中脱颖而出,吸引更多用户。
42 5
|
2月前
|
机器学习/深度学习 前端开发 JavaScript
前端小白也能学会的高大上技巧:如何让你的网页支持语音控制?
【10月更文挑战第31天】你是否曾梦想过只需动动嘴皮子就能操控网页?现在,这个梦想触手可及。即使你是前端小白,也能轻松学会让网页支持语音控制的高大上技巧。本文将介绍语音控制的基本概念、实现方法和具体示例,带你走进语音控制的奇妙世界。通过Web Speech API,你只需掌握基本的HTML、CSS和JavaScript知识,就能实现语音识别和控制功能。快来尝试吧!
237 4
|
2月前
|
前端开发 JavaScript 数据处理
前端界的宝藏技术:掌握这些,让你的网页秒变交互神器!
【10月更文挑战第31天】前端开发藏有众多宝藏技术,如JavaScript异步编程和Web Components。异步编程通过Promise、async/await实现复杂的网络请求,提高代码可读性;Web Components则允许创建可重用、封装良好的自定义组件,提升代码复用性和独立性。此外,CSS动画、SVG绘图等技术也极大丰富了网页的视觉和交互体验。不断学习和实践,让网页秒变交互神器。
36 2
|
2月前
|
编解码 前端开发 开发者
前端开发的必修课:如何让你的网页在不同设备上完美呈现?
【10月更文挑战第30天】随着互联网的普及,用户访问网页的设备种类繁多。前端开发者需确保网页在不同设备上完美呈现。本文介绍了一些最佳实践,包括使用响应式设计、相对单位、灵活的图片和视频、测试与优化及考虑交互设计,帮助实现跨设备兼容。
70 2
|
2月前
|
缓存 前端开发 JavaScript
前端小白也能掌握的高级技巧:如何让你的网页支持PWA特性?
【10月更文挑战第30天】随着互联网技术发展,渐进式网页应用(PWA)成为提升用户体验的重要手段。本文通过一个案例,介绍如何为在线问答社区网页应用添加PWA特性。从创建基本结构、添加Service Worker、创建Manifest文件到测试PWA特性,详细展示了每一步的操作方法。适合前端小白学习参考。
32 2