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


相关文章
|
1月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
505 7
|
1月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
604 1
|
1月前
|
缓存 小程序 索引
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
197 1
|
1月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
588 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
30天前
|
存储 小程序 安全
微信的开发管理都需要配置什么?
【10月更文挑战第17天】微信的开发管理都需要配置什么?
30 0
|
1月前
|
JavaScript 小程序 开发者
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
337 0
|
1月前
|
小程序
uni-app开发微信小程序使用onPullDownRefresh(下拉刷新)总结
uni-app开发微信小程序使用onPullDownRefresh(下拉刷新)总结
514 0
|
1月前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
223 3
|
1月前
|
小程序 API
微信小程序更新提醒uniapp
在小程序开发中,版本更新至关重要。本方案利用 `uni-app` 的 `uni.getUpdateManager()` API 在启动时检测版本更新,提示用户并提供立即更新选项,自动下载更新内容,并在更新完成后重启小程序以应用新版本。适用于微信小程序,确保用户始终使用最新版本。以下是实现步骤: ### 实现步骤 1. **创建更新方法**:在 `App.vue` 中创建 `updateApp` 方法用于检查小程序是否有新版本。 2. **测试**:添加编译模式并选择成功状态进行模拟测试。
49 0
微信小程序更新提醒uniapp
|
3月前
|
小程序 前端开发 Java
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
JavaDog Chat v1.0.0 是一款基于 SpringBoot、MybatisPlus 和 uniapp 的简易聊天软件,兼容 H5、小程序和 APP,提供丰富的注释和简洁代码,适合初学者。主要功能包括登录注册、消息发送、好友管理及群组交流。
106 0
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目

热门文章

最新文章

下一篇
无影云桌面