Uniapp在Vue环境中引入iconfont图标库(详细教程)

Uniapp在Vue环境中引入iconfont图标库(详细教程)

开发工具环境HBuilderX4.29

1 iconfont图标库下载

在项目根目录下创建common文件夹,我们需要把一些常用的全局样式放入此文件夹下

阿里巴巴icon官网:https://www.iconfont.cn/,进入官网后注册登录账号,然后进入icon图标库

搜索商城,寻找任意喜欢的图标字库,例如:

找到需要的图标分别加入购物车里

点击购物车,将刚才添加的图标添加到我的项目里(如果没有项目则自己新建一个)

进入我的项目里,然后下载刚刚添加的图标库文件

2 iconfont图标库引入

下载完成后复制这三个字体文件到自己的项目工程里,放在static下的font文件夹下,如果没有则新建


复制iconfont.css文件到项目工程的common目录下,同时打开iconfont.css进行编辑,把URL字体库换成自己项目的相对路径

以下是对三种字体库的说明

字体格式 文件体积 加载速度 浏览器支持 备注
TTF 较大 较慢 几乎所有现代浏览器 文件格式简单,易于生成和编辑
WOFF 中等 较快 广泛支持 具有版权保护机制
WOFF2 最小 最快 现代浏览器 压缩率更高,文件体积更小

实际应用

在实际项目中,通常会同时提供多种格式的字体文件,以便浏览器根据自身支持的格式选择最合适的字体文件。例如:

css 复制代码
@font-face {
  font-family: "iconfont"; /* Project id 4729183 */
    src: url('../static/font/iconfont.woff2?t=1730288388234') format('woff2'),
         url('../static/font/iconfont.woff?t=1730288388234') format('woff'),
         url('../static/font/iconfont.ttf?t=1730288388234') format('truetype');
}

这样做的好处是:

  • 兼容性:确保所有浏览器都能找到合适的字体文件。
  • 性能:现代浏览器优先选择 WOFF2 文件,提高加载速度。

在app.vue下加入全局样式引入代码,原代码保留,新增引入iconfont图标库

vue 复制代码
<style lang="scss">
	/*引入iconfont图标库*/
	@import '@/common/iconfont.css';
</style>

3 iconfont图标库使用

官方示例说明

打开之前下载的示例文件,在我们之前下载的文件中有一个使用示例html,打开后有使用说明

在我们项目中比较常用的是直接class类引用的方式,可以查看引用说明

打开之前新建的test测试页添加如下测试代码,将之前下载的四个图标全部引用

vue 复制代码
<template>
	<view>
		<text class="iconfont icon-gouwuche"></text>
		<text class="iconfont icon-fenlei"></text>
		<text class="iconfont icon-shouye"></text>
		<text class="iconfont icon-wode"></text>
	</view>
</template>

<script setup>

</script>

<style lang="scss" scoped>
	/* 添加一些样式 */
	text {
		color: red;
		margin-right: 60rpx;
		font-size: 100rpx;
	}
</style>

将Uniapp项目运行到微信小程序或者本机的app上,微信小程序运行后显示效果

相关推荐
木头没有瓜23 分钟前
vscode离线安装插件
ide·vue.js·vscode
伍哥的传说1 小时前
鸿蒙系统(HarmonyOS)应用开发之手势锁屏密码锁(PatternLock)
前端·华为·前端框架·harmonyos·鸿蒙
yugi9878381 小时前
前端跨域问题解决Access to XMLHttpRequest at xxx from has been blocked by CORS policy
前端
浪裡遊1 小时前
Sass详解:功能特性、常用方法与最佳实践
开发语言·前端·javascript·css·vue.js·rust·sass
旧曲重听12 小时前
最快实现的前端灰度方案
前端·程序人生·状态模式
默默coding的程序猿2 小时前
3.前端和后端参数不一致,后端接不到数据的解决方案
java·前端·spring·ssm·springboot·idea·springcloud
夏梦春蝉2 小时前
ES6从入门到精通:常用知识点
前端·javascript·es6
归于尽2 小时前
useEffect玩转React Hooks生命周期
前端·react.js
G等你下课3 小时前
React useEffect 详解与运用
前端·react.js
我想说一句3 小时前
当饼干遇上代码:一场HTTP与Cookie的奇幻漂流 🍪🌊
前端·javascript