引入阿里iconfont图标方法以及注意事项

图片

背景

在我们做日常项目时,通常会用到icon图标或者是一些图标字体,阿里iconfont是我们选择的较多的一种,下面我将会介绍使用方法和几种常用的引用方式

iconfont新建项目

官网:https://www.iconfont.cn/ 在首页选择【图标管理】-【我的项目】

图片

点击 【我的项目】

图片

图片

填写项目信息,即可完成新建一个项目。【FontClass/Symbol 前缀】和【Font Family】参数是自定义的,以后会与我们生成的代码相关联,默认即可。

添加图标

新建好项目后,找到自己想要的图标,加入购物车。

图片

点击页面右上角的购物车图标,打开自己的购物车,选择添加至项目,我们就可以在自己的项目下看到添加的图标了。

图片

在我们的项目下,可以对图标进行编辑,如:大小、颜色、填充色,旋转等操作。

图片

图片

Vue工程中引入iconfont

****官方文档:****https://www.iconfont.cn/help/detail?spm=a313x.7781069.1998910419.15&helptype=code

根据官方文档,有unicode引用、font-class引用、symbol引用三种引入方式,这三种方式又分有两种情况:下载到本地引入在线链接引入。在Iconfont网页我们自己的项目下可以看到这些方式选择。

图片

unicode引用 不推荐

  • 本地引入

unicode方式代码量少,并不需要下载本地文件。

  • 链接引入

unicode模式下的在线链接指的是font-face代码。

在vue中,将项目生成的font-face代码和自定义的iconfont样式写在App.vue的style中,就可以在项目中引用图标了。此时样式是全局作用的,如果想要实现图标不同的样式,可以增加一层自定义样式。

<i class="iconfont myIconStyle">&#xe64a;</i>

在”myIconStyle”样式中修改color等属性可以覆盖全局的样式,实现单个的样式修改。

这里注意理解下,官方文档说的“不支持多色”,是指我们iconfont网页项目中,就算有多色图标,引用的时候会自动去色,统一变成默认的颜色,不管你给图标一编辑了红色图标二编辑了黄色,在项目中用unicode方式引用的时候都会变成默认颜色,但是我们仍然可以通过修改css样式实现图标颜色自定义,只是这个颜色编辑放在代码层面来了。

font-class引用 推荐使用

如官方文档所说,font-class是为了让程序更加直观可读,直接用unicode会造成阅读困难。font-class模式关键在于生成的css文件。

  • 本地引入

按照下图选择文件放入自己的项目中,vue中建议在assets文件夹下新建一个iconfont文件夹,放相关文件。

图片

常用的就是:iconfont.css、iconfont.ttf、iconfont.woff、iconfont.woff2

@font-face {
  font-family: "iconfont"; /* Project id 2974228 */
  src: url('iconfont.woff2?t=1640340931514') format('woff2'),
      url('iconfont.woff?t=1640340931514') format('woff'),
      url('iconfont.ttf?t=1640340931514') format('truetype');
}

再就是引入时,需要注意的是字体文件路径引用是否准确,否则打包可能不识别

然后在main.js中引入iconfont.css文件,就可以正常使用了。

import './assets/iconfont/iconfont.css'
  • 链接引入

方式一:

在index.html头部中,引入css文件即可

<link rel="stylesheet" type="text/css" href="http://at.alicdn.com/t/font_1160473_t1iruikumm.css">

方式二:

点开css代码链接

图片

图片

复制css代码,在项目中粘贴到iconfont.css文件中 ,在App.vue或main.js中引入

import './assets/iconfont/iconfont.css'

注意:iconfont.css中url 官方默认是cdn 链接, 打包时请改成http否则不识别

@font-face {
  font-family: "iconfont"; /* Project id 2974228 */
  src: url('//at.alicdn.com/t/font_2974228_90efgxrmkr8.woff2?t=1639986814919') format('woff2'),
       url('//at.alicdn.com/t/font_2974228_90efgxrmkr8.woff?t=1639986814919') format('woff'),
       url('//at.alicdn.com/t/font_2974228_90efgxrmkr8.ttf?t=1639986814919') format('truetype');
}

打包后

@font-face {
    font-family: "iconfont"; /* Project id 2400747 */
    src: url('http://at.alicdn.com/t/font_2400747_k5sq86ts4b.woff2?t=1634895844844') format('woff2'),
    url('http://at.alicdn.com/t/font_2400747_k5sq86ts4b.woff?t=1634895844844') format('woff'),
    url('http://at.alicdn.com/t/font_2400747_k5sq86ts4b.ttf?t=1634895844844') format('truetype');
}

symbol引用 不推荐

  • 本地引入

将下载好的iconfont.js文件放入自己的工程目录,在main.js中引入,在App.vue中写好通用css代码,即可使用。

import './assets/iconfont/iconfont.js'

这里注意一点,下载下来的js文件是压缩过的,如果项目使用了eslint语法校验会疯狂报错,可以在js文件开头加入 /* eslint-disable */来指定该文件不应用eslint校验。

  • 链接引入

在index.html头部中,引入js文件即可

<script src="//at.alicdn.com/t/font_1160473_t1iruikumm.js"></script>

uni-app 引入iconfont图标

基本上引入方式跟上Vue相同,但是会遇到打包时图标引入不显示的问题,解决方式如下:

1.在iconfont.css中,需要使*~@* 将路径添加完整

@font-face {
  font-family: "iconfont"; /* Project id 2642111 */
  src: url('~@/static/fonts/iconfont.woff2?t=1625021641165') format('woff2'),
       url('~@/static/fonts/iconfont.woff?t=1625021641165') format('woff'),
       url('~@/static/fonts/iconfont.ttf?t=1625021641165') format('truetype');
}

2.在App.vue全局引入iconfont.css

<style>
/* 每个页面公共css */
@import url("~@/static/fonts/iconfont.css");
/* #ifdef MP-TOUTIAO */
/* #endif */
</style>
3.使用图标,在标签内的class通过"iconfont icon-"添加下载好的图标即可
<view class="iconfont icon-yuangongguanli"></view>

或通过官方uni-icons 引入自定义图标

<uni-icons slot="icon" customPrefix="iconfont" class="icon-fenxiang" color="#f8bd12" size="20"/>

总结

symbol引用最受官方推荐,也是最优的方式,但是浏览器兼容不好,目前来看,前端需要兼容一些低版本的浏览器,所以如果考虑到用户使用,不建议采用symbol引用。

unicode引用浏览器兼容最好,但是可读性差,font-class引用虽然兼容性比unicode引用差一点,但是提高可读性,综合来看,目前项目中还是采用font-class引用比较好。

因为引用网络资源的不稳定,所以建议采用本地引入的方式。

如果在图标库中新增加了图标,则需要更新在线链接并把该链接重新引入到实际项目中,或者重新下载代码到本地,然后在实际项目中引入最新的iconfont文件。

再就是引入时文件路径的问题,打包都需要注意。

  • 9
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 要在uniapp中引入iconfont图标,可以按照以下步骤操作: 1. 在iconfont官网上选择需要的图标,添加到购物车中并下载。 2. 解压下载的文件,将其中的iconfont.ttf文件复制到项目的static文件夹中。 3. 在App.vue文件中引入iconfont.css文件,可以使用@import语句或者在head标签中添加link标签。 4. 在需要使用图标的地方,使用<i>标签,并设置class属性为iconfont和对应的图标类名,例如<i class="iconfont icon-home"></i>。 5. 在样式中设置字体大小、颜色等属性即可。 注意:如果需要使用多个iconfont图标库,需要将它们的字体文件和css文件分别放在不同的文件夹中,并在App.vue文件中分别引入。同时,不同的图标库可能会有相同的类名,需要注意避免冲突。 ### 回答2: UniApp是一个跨平台的应用程序开发框架,它是基于Vue.js开发的。在UniApp中,可以通过引入iconfont图标来实现应用程序的界面美化和功能增强。 Iconfont是一款阿里巴巴提供的矢量图标库,它提供了丰富的图标种类和多种样式,而且可以非常方便地在网页和移动端应用中使用。在UniApp中引入Iconfont图标只需要四个简单的步骤: 第一步,注册Iconfont账号并登录,然后创建一个新的项目,选择需要的图标,然后打包下载。 第二步,将下载的图标包解压,并将其中的iconfont.cssiconfont.ttf文件复制到UniApp项目的static目录下。 第三步,修改App.vue中的main.js文件,在文件中引入iconfont.css文件。具体代码如下: import './static/iconfont.css'; 第四步,在需要使用Iconfont图标的页面中,通过类名的方式引入需要的图标。具体代码如下: <i class="iconfont">&#xeXXX;</i> 其中,XXX为所需图标的Unicode编码。 通过以上四个步骤的操作,就可以在UniApp中引入Iconfont图标了。相比于其他的字体图标库,Iconfont图标库具有占用空间小、加载快等优点,可以提升应用程序的用户体验。同时,因为Iconfont图标是矢量图标,所以可以随意放大缩小而不失真,这也使得它在高分辨率屏幕上有很好的表现效果。总之,UniApp引入Iconfont图标是一个很好的实践操作,可以帮助开发者打造更美观、更实用的应用程序。 ### 回答3: uniapp是一个开发跨平台应用的框架,常用于开发小程序、H5应用和快应用等。为了美化应用界面,我们需要引入图标,而iconfont是一个非常好的图标库。 要在uniapp中引入iconfont图标,我们需要进行以下几个步骤: 1.注册iconfont账户并创建图标库,登录后可在控制台中查看自己的项目ID和字体库ID。 2.到iconfont官网上下载字体文件,将其解压后复制到uniapp项目中的static目录下(也可以放在其他文件夹中)。 3.打开字体图标库,选择需要引入图标,将它们添加到购物车中,再点击购物车中的“下载代码”按钮,在弹出的框中勾选“Symbol”选项,选择需要生成的字体格式和文件路径,然后点击下载按钮。 4.下载完成后,将下载包解压,把其中的iconfont.cssiconfont.ttf文件复制到uniapp项目中的static文件夹下(或者其他文件夹,但这里需要修改css文件中字体文件的路径)。 5.在需要使用图标的页面的vue文件中,通过style标签引入iconfont.css文件,然后使用<i>标签加上相应的类名即可显示对应的图标。示例代码如下: ```html <style> @font-face { font-family: 'iconfont'; src: url('./static/iconfont.ttf') format('truetype'); } .icon { font-family: 'iconfont' !important; font-size: 20px; font-style: normal; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } </style> <template> <div> <i class="icon iconfont"></i> <!-- 这里的类名是在iconfont官网上选择的 --> <i class="icon iconfont"></i> </div> </template> ``` 通过以上步骤,我们就可以在uniapp中引入iconfont图标库,并在页面中使用了。这样可以让应用更加美观,提升用户体验。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值