微信小程序开发 | 如何在小程序中使用自定义 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/


相关文章
|
自然语言处理 搜索推荐 小程序
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。
|
7月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
8月前
|
小程序 JavaScript API
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
这篇文章介绍了使用uni-halo框架进行微信小程序开发的过程,包括选择该框架的原因、开发目标以及项目配置和部署的步骤。
456 0
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
|
11月前
|
小程序 前端开发 Android开发
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
2202 29
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
|
人工智能 开发框架 机器人
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
AstrBot 是一个开源的多平台聊天机器人及开发框架,支持多种大语言模型和消息平台,具备多轮对话、语音转文字等功能。
8299 38
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
|
人工智能 自然语言处理 小程序
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
3733 11
技术小白如何利用DeepSeek半小时开发微信小程序?
|
小程序 Java 关系型数据库
weixin163基于微信小程序的校园二手交易平台系统设计与开发ssm(文档+源码)_kaic
本文介绍了一款基于微信小程序的校园二手物品交易平台的开发与实现。该平台采用Java语言开发服务端,使用MySQL数据库进行数据存储,前端以微信小程序为载体,支持管理员和学生两种角色操作。管理员可管理用户、商品分类及信息、交易记录等,而学生则能注册登录、发布购买商品、参与交流论坛等。系统设计注重交互性和安全性,通过SSM框架优化开发流程,确保高效稳定运行,满足用户便捷交易的需求,推动校园资源共享与循环利用。
|
小程序 关系型数据库 Java
weixin168“返家乡”高校暑期社会实践微信小程序设计与开发ssm(文档+源码)_kaic
本文探讨高校暑期社会实践微信小程序的开发与应用,旨在通过信息化手段提升活动管理效率。借助微信小程序技术、SSM框架及MySQL数据库,实现信息共享、流程规范和操作便捷。系统涵盖需求分析、可行性研究、设计实现等环节,确保技术可行、操作简便且经济合理。最终,该小程序可优化活动发布、学生信息管理和心得交流等功能,降低管理成本并提高工作效率。
|
小程序 JavaScript 前端开发
微信小程序开发全流程:从注册到上线的完整指南
这篇文章详细记录了微信小程序的完整开发到最终上线的每一个步骤。适合对小程序开发感兴趣的个人开发者或希望了解完整流程的学习者,涵盖了云开发、事件绑定、生命周期管理、组件使用等关键内容。
16733 14
|
JSON 缓存 小程序
微信小程序组件封装与复用:提升开发效率
本文深入探讨了微信小程序的组件封装与复用,涵盖组件的意义、创建步骤、属性与事件处理,并通过自定义弹窗组件的案例详细说明。组件封装能提高代码复用性、开发效率和可维护性,确保UI一致性。掌握这些技能有助于构建更高质量的小程序。

热门文章

最新文章

下一篇
开通oss服务