微信小程序开发 | 如何在小程序中使用自定义 icon 图标

简介: 微信小程序开发 | 如何在小程序中使用自定义 icon 图标

e1b989e7f9330c20da5021dd7e34443a_640_wx_fmt=jpeg&wxfrom=5&wx_lazy=1&wx_co=1.jpg题图:来自 Unsplash.com


本文是微信小程序开发学习笔记。微信小程序 icon 组件(标签)只提供了 9 种类型的图标,不能满足开发或设计的个性化需求。为了解决这个问题,我们可以使用自定义的 icon 图标,来丰富原有的图标类型。b5b7b7944054f7857a82072bbbf66fc8_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png在微信小程序中使用自定义 icon 图标有 6 种方法:


1.使用 icon 图标(特指位图)

2.使用 Sprite(精灵图)

3.使用 CSS 样式绘制(这种方法工作量大)

4.使用矢量字体

5.使用 SVG 矢量文件

6.使用 Canvas


本文只对第 4 种方法进行说明,因为除了第 1 种方法,其他方法我暂时还都不会。使用矢量字体来自定义 icon 图标,需要用到阿里巴巴图标库网站 Iconfont[1]。题外话,以前我一直以为这个网站只能用于设计,直到接触了一些前端的知识,才知道它也能运用到编程中。打开网站,选择一个自己喜欢的图标,将其添加到购物车,类似购物时将商品添加到购物车的操作,重复操作,将你喜欢的图标一一添加到购物车中。310811212983daf772cf920109220b14_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png选择好需要的所有图标后,点击右上角的「购物车」图标。3691055f9ed92cc2f6b1c0c5ea492b25_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png浏览器右侧会弹出一个面板,选择「添加至项目」,如果你之前未曾创建过项目,这里就需要新建一个项目,新建项目其实就是新建一个文件夹。fcae906bfb033ed2ad7ce200f080b617_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png将鼠标移动到网页顶部的导航栏「图标管理」,在弹出的菜单中,点击「我的项目」。0caedb4c043d5600bd05eedc9848e7cd_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png在我的项目中,点击「查看在线链接」。52b3d3747b829f13c3cae30119063ceb_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png下方会出现一长串代码,其中的 url 链接指向的就是存放在阿里云服务器的矢量字体,这些字体有不同的格式,如 ttf、woff、woff2,之所以需要用到不同的字体格式,是为了兼容不同的设备或系统。接着点击「点此复制代码」,将代码复制到系统剪贴板中。3dc2e53e3c751c3f5c7824ce7325f5b1_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png回到微信小程序开发者工具中,将代码粘贴到小程序页面的 wxss 文件中,wxss 文件可以类比为普通网页的 css 文件。1664d3b19b5169d7e039079fdf47b6a9_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png接着在 wxss 文件中进一步定义 icon 图标的样式,输入以下的代码:

.iconfont{
  font-family: 'iconfont';
  color: red;
  font-size: 30px;
}
.icon-heart::before{
  content: '\e8ab';
}
.icon-like::before{
  content: '\e8ad';
}

font-family 指定我们嵌入的字体名称,它需要与 @font-face 中 font-family 的值保持一致 ,color 设置图标的颜色,font-size 设置图标的大小。

icon-heart 和 icon-like 是自定义的类选择器名称(简称类名),你可以根据自己的喜好进行命名,这里的 icon-heart 代表爱心图标,icon-like 代表点赞图标。content 指定图标的 unicode 编码,获取图标的编码还需要回到 iconfont,将鼠标移动到图标上方,在弹出的菜单中,选择「编辑图标」。3b30dc82ee164496e0a886f0c11e5ed9_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png在打开的页面中,左下角的 4 位字符——e8ab,就是爱心图标的 unicode 编码,将其粘贴到 wxss 文件中对应的位置,并在字符前面加上一个反斜杠 \。

a8451094b11c7209aa3c17b16c60c727_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png获取点赞图标的 unicode 编码,也需要进行同样的操作。

至此,就算完成了 wxss 样式的编辑。为了在小程序中看到图标最终的渲染效果,我们还需要编辑一下 wxml 文件,wxml 相当于普通网页的 html 文件。在 wxml 中使用 icon 标签,输入如下代码:  

  <icon class="iconfont icon-heart"></icon>
  <icon class="iconfont icon-like"></icon>
  • 这里的 class 属性的值,就是对应 wxss 文件中自定义的类名,通过类名来应用相应的样式。

完成以上所有操作,最终的渲染效果如下:750f6d667f9911a191e30708935077f5_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

搞得那么费劲,就只为得到两个小图标。。。好像有点得不偿失 🙉🙊🙈🐵🐶


扩展阅读:

写一个微信小程序的最少必要知识

以上,希望有帮助。

References

[1] Iconfont: https://www.iconfont.cn/


相关文章
|
4天前
|
小程序 开发者
第一个微信小程序的初始化过程、小程序微信开发平台的下载、如何注册一个微信小程序的账号
这篇文章介绍了微信小程序的初始化过程,包括如何注册微信小程序账号、下载微信小程序开发者平台,并指导了新建小程序的详细步骤。
第一个微信小程序的初始化过程、小程序微信开发平台的下载、如何注册一个微信小程序的账号
|
2天前
|
小程序 前端开发 JavaScript
微信小程序结合PWA技术,提供离线访问、后台运行、桌面图标及原生体验,增强应用性能与用户交互。
微信小程序结合PWA技术,提供离线访问、后台运行、桌面图标及原生体验,增强应用性能与用户交互。开发者运用Service Worker等实现资源缓存与实时推送,利用Web App Manifest添加快捷方式至桌面,通过CSS3和JavaScript打造流畅动画与手势操作,需注意兼容性与性能优化,为用户创造更佳体验。
9 0
|
1月前
|
小程序 安全 搜索推荐
【微信小程序开发实战项目】——如何制作一个属于自己的花店微信小程序(3)
这是一篇关于微信小程序开发的文章摘要,作者介绍了如何创建一个网上花店小程序,旨在提供便捷的购花体验。小程序包含鲜花分类功能,允许用户按品种、颜色和用途筛选,确保快速找到合适的鲜花。它还提供了配送服务,保证鲜花的新鲜度。文章展示了`cash.wxml`、`cash.wxss`和`cash.js`的部分代码,用于实现分类和商品展示,以及`qin.wxml`、`qin.wxss`和`qin.js`,涉及商品详情和购买付款流程。代码示例展示了商品列表渲染和交互逻辑,包括页面跳转、数据传递和点击事件处理。文章最后提到了购买付款界面,强调了安全和便捷的支付体验。
68 0
【微信小程序开发实战项目】——如何制作一个属于自己的花店微信小程序(3)
|
1月前
|
小程序 开发者
【微信小程序】 微信小程序报错不在以下request合法域名列表中
【微信小程序】 微信小程序报错不在以下request合法域名列表中
118 0
|
1月前
|
前端开发 小程序
【微信小程序-原生开发】实用教程20 - 生成海报(实战范例为生成活动海报,内含生成指定页面的小程序二维码,保存图片到手机,canvas 系列教程)
【微信小程序-原生开发】实用教程20 - 生成海报(实战范例为生成活动海报,内含生成指定页面的小程序二维码,保存图片到手机,canvas 系列教程)
122 0
|
1月前
|
小程序 前端开发
【微信小程序-原生开发】添加自定义图标(以使用阿里图标库为例)
【微信小程序-原生开发】添加自定义图标(以使用阿里图标库为例)
39 0
|
6天前
|
存储 小程序 JavaScript
|
6天前
|
小程序 前端开发 安全
|
1月前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的汉服交易小程序的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的汉服交易小程序的详细设计和实现(源码+lw+部署文档+讲解等)
30 7
|
1月前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的宠物医院微信小程序的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的宠物医院微信小程序的详细设计和实现(源码+lw+部署文档+讲解等)
46 7

热门文章

最新文章