小程序模板网

3步在小程序中使用iconfont.md

发布时间:2018-04-25 10:44 所属栏目:小程序开发教程

				

众所周知, 小程序的有一个1M大小的限制. 而优美的界面离不了各种图形. 如果将这些图形集成到小程序中. 其臃肿的体积是让微信官方不想接受的.

作为前端开发, 阿里给我早就了iconfont开源图标库. 那能不能把这些图标字体引入到小程序中. 让水火不容的AT来一次拥抱.

说干就干.

从iconfont中下载iconfont源文件

http://iconfont.cn/

我们加几个图标字体. 单色的. 多色的.,最后得到的图标

将iconfont资源下载到本地备用. 下载完压缩包内容如下.

 

打开新建小程序

直接选用QuickStart建立一个默认程序

加入iconfont到小程序项目中

建立文件夹 /assets/iconfont/ , 将解压出来的iconfont文件均放入此文件夹. (测试时都放入. 教程完成后. 我们要留下最精简的文件)

将iconfont引入小程序中

将iconfont.css加入

在全局样式 app.wxss中, 第一行加入代码

@import "/assets/iconfont/iconfont";

引入时会报错"File not found: /assets/iconfont/iconfont", 这是小程序只认识以wxss为后缀的css文件. 标准的.css文件是不能识别的.

将`

/assets/iconfont/iconfont.css改名为

iconfont.wxss

`即可解决.

在/pages/index/index.wxml中加入iconfont的调用代码

修改 代码段的内容

 

  1.  
  2. <view class="usermotto">
  3. <view>
  4. <text class="name">窗口(彩色)</text>
  5. FontClass方式
  6. <i class="icon iconfont icon-chuangkou"></i>
  7. </view>
  8. <view>
  9. <text>窗口(单色)</text>
  10. FontClass方式
  11. <i class="icon iconfont icon-yonghu_qiandao"></i>
  12. </view>

通过加入iconfont.css方式, 可以使用单色的iconfont字体.不能使用彩色的.

加入如下代码.

 

  1. <i class="icon iconfont icon-chuangkou"></i>

预览小程序,在ANDROID和ios上的显示

android( Nubia Z17mini)

显示效果一致.

精简iconfont

删除/assert/iconfont/下除iconfont.wxss以外的所有有文件. 仅保留iconfont.wxss

修改iconfont.wxss

 

  1.  
  2. @font-face {font-family: "iconfont";
  3. src: url('data:application/x-font-woff; <<此处省略>> AAAAA==') format('woff');
  4.  
  5. }

<< 后面保持不变>>

搞定,经测试在android 和 ios下表现一致.

如何更新图标

在iconfont.cn中添加图标,并下载iconfont压缩包.

复制压缩包内文件iconfont.css的内容到, 小程序项目中/assets/iconfont/iconfont.wxss中, 删除不需要的行(参照精简iconfont中的wxss). 即可.

再给你一个懒人黑科技把. 直接复制`

iconfont.css到

iconfont.wxss

`中

,不删除任何内容, 小程序依然表现良好.

总结

简单说三步搞定iconfont在小程序中的使用

  1. 在iconfont.cn中下载图标库, 直接将其中的iconfont.css复制到小程序目录中,并将扩展名改为wxss.

  2. 在使用时在对应的样式文件wxss中加入一行引用`

@import "/path/to/iconfont";`,

可以在wxml中使用了.



易优小程序(企业版)+灵活api+前后代码开源 码云仓库:starfork
本文地址:https://www.eyoucms.com/wxmini/doc/course/24040.html 复制链接 如需定制请联系易优客服咨询:800182392 点击咨询
QQ在线咨询