前端模块化之图标使用

简介: 对图标进行封装,以便于更简单、方便的使用图标

上一篇文章讲了css初始化,这一篇接着讲图标 icon 的使用。
现在网站中大多数,我们都有使用图标,这里推荐一个好的图标网站 iconfont,并且由于现在由于浏览器对于 SVG 的兼容性越来越好了,所以现代的图标大部分已经开始基于 svg 的方式了。
这个库对于 svg 图标进行了封装,能够方便使用图标。

安装

yarn add phui

使用

使用单色图标

iconfont使用帮助 里面的 symbol 引用中详细介绍了使用方式,首先需要引入图标集的文件。

  1. 可以通过 script 方式引入,也可以通过 import 的形式引入。

    <script src="./icons.js" async></script> // import './icons.js'
  2. html 节点中添加节点用于渲染图标

    <svg id="info" class="info-icon"></svg>

    可以直接在节点上添加需要的 class

  3. 接下来就是正确使用了。

    import SingleIcon from 'phui/lib/Icon/SingleIcon'
    
    new SingleIcon('#info', 'info', 'icon-')

    SingleIcon 类接收3个参数:

    1. el: string | Element 必选,渲染图标的节点,可以是选择器也可以是 HTML 节点。
    2. icon: string 必填,使用的图标名称对应到添加图标入库时的名称,可以不包括前缀。
    3. prefix: string 选填,默认为 icon-,可以填写为自己添加入库时的前缀。

    prefix + icon 就是完整的入库时的名称了。

通过这种方式使用图标方便、简单;但同时也有不便的地方,所有的图标合在一起引入,不方便做按需引入,对于性能有影响的时候,不太好,同时这种方式对于图标如果只有一种方式,并且在添加入库的时候, path 节点没有通过 fill 填充颜色的,可以通过 css - color 来改变颜色;如果对于多色图标想要更改颜色就不行了。

图标的按需引入

库里面提供了以下图标方便按需引入。
1636528796(1).png
依次分别为 InfoIconWarnIconSuccessIconErrorIconLoadingIcon
添加渲染节点

<svg id="info"></svg>
<svg id="warn"></svg>
<svg id="success"></svg>
<svg id="error"></svg>
<svg id="loading"></svg>

渲染图标

import InfoIcon from 'phui/lib/InfoIcon'
import WarnIconfrom 'phui/lib/WarnIcon'
import SuccessIconfrom 'phui/lib/SuccessIcon'
import ErrorIconfrom 'phui/lib/ErrorIcon'
import LoadingIcon from 'phui/lib/LoadingIcon'

new InfoIcon('#info')
new WarnIcon('#warn')
new SuccessIcon('#success')
new ErrorIcon('#error')
new LoadingIcon('#loading')

有时候我们不希望渲染图标到节点,只想要图标字符串的时候,可以把第一个参数设置为空字符串

let infoIcon = new InfoIcon('')
console.log(infoIcon.toString())

如果想要为图标添加 class 样式,例如修改图标颜色[color]、修改图标大小[font-size]。

new InfoIcon('#info', { class: 'info-icon' }) // .info-icon{color:red,font-size:16px;}

自定义图标

我们也可以自定义图标

import Icon from 'phui/lib/Icon'

// 定义类继承Icon,并重写 _template 方法,返回图标的 svg-path
class MultiLoadingIcon extends Icon {
  /* 重写 _template 方法,返回图标的 svg-path,同时在path上加上fill属性,便于修改多色图标颜色 */
  protected _template() {
    return '<path d="M204.8 204.8m-204.8 0a204.8 204.8 0 1 0 409.6 0 204.8 204.8 0 1 0-409.6 0Z" fill="#EBF2FC" p-id="2687"></path><path d="M819.2 204.8m-204.8 0a204.8 204.8 0 1 0 409.6 0 204.8 204.8 0 1 0-409.6 0Z" fill="#B5D2F3" p-id="2688"></path><path d="M819.2 819.2m-204.8 0a204.8 204.8 0 1 0 409.6 0 204.8 204.8 0 1 0-409.6 0Z" fill="#7FB0EA" p-id="2689"></path><path d="M204.8 819.2m-204.8 0a204.8 204.8 0 1 0 409.6 0 204.8 204.8 0 1 0-409.6 0Z" fill="#4A90E2" p-id="2690"></path>'
  }
}

new MultiLoadingIcon('#multi')

以上代码渲染出的图标为:
1636530546(1).png
如果在重写 _template 函数的时候,返回的 path 节点加上了 fill 属性,也支持改变颜色,例如:

new MultiLoadingIcon('#multi1', { fills: ['#5FB878', '#1E9FFF', '#FFB800', '#FF5722'] })

以上代码渲染出的图标为:
1636530694(1).png

相关文章
|
8月前
|
资源调度 前端开发 JavaScript
构建高效前端项目:现代包管理器与模块化的深度解析
【2月更文挑战第21天】 在当今快速演变的前端开发领域,高效的项目管理和代码组织已成为成功交付复杂Web应用的关键。本文将深入探讨现代前端包管理器如npm, yarn和pnpm的工作原理,以及它们如何与模块化编程实践(例如CommonJS、ES6模块)协同工作以优化开发流程。我们将剖析这些工具的内部机制,了解它们如何解决依赖冲突,提高安装速度,并保证项目的健壮性。同时,本文还将介绍模块化编程的最佳实践,包括代码拆分、重用和版本控制,帮助开发者构建可维护且性能卓越的前端项目。
|
8月前
|
前端开发 JavaScript jenkins
构建高效前端项目:从模块化到自动化
【2月更文挑战第13天】 随着Web技术的不断进步,前端项目的复杂性日益增加。为了确保可维护性和性能,前端工程师必须采用模块化和自动化的策略来优化开发流程。本文将探讨如何使用现代前端工具和最佳实践来构建一个高效的前端项目架构,包括模块打包、代码分割和持续集成等方面。
|
3月前
|
JavaScript 前端开发 Java
VUE学习四:前端模块化,ES6和ES5如何实现模块化
这篇文章介绍了前端模块化的概念,以及如何在ES6和ES5中实现模块化,包括ES6模块化的基本用法、默认导出与混合导出、重命名export和import,以及ES6之前如何通过函数闭包和CommonJS规范实现模块化。
146 0
VUE学习四:前端模块化,ES6和ES5如何实现模块化
|
3月前
|
前端开发 JavaScript 开发者
深入解析前端开发中的模块化与组件化实践
【10月更文挑战第5天】深入解析前端开发中的模块化与组件化实践
41 1
|
5月前
|
前端开发
如何在前端项目中单独引入 ElementUI 图标以及使用
这篇文章介绍了如何在前端项目中单独引入Element UI的图标文件以及如何使用这些图标。
428 0
如何在前端项目中单独引入 ElementUI 图标以及使用
|
5月前
|
前端开发 JavaScript
前端必会的JavaScript模块化
【8月更文挑战第3天】JavaScript模块化
37 1
|
5月前
|
前端开发
前端ElementPlus框架中的几种图标按钮使用方式
本文介绍了如何在Element Plus前端框架中使用带有图标的按钮,包括设置按钮大小、图标大小、按钮类型以及如何为图标添加点击事件。
463 0
|
6月前
|
开发框架 前端开发 JavaScript
循序渐进VUE+Element 前端应用开发(11)--- 图标的维护和使用
循序渐进VUE+Element 前端应用开发(11)--- 图标的维护和使用
|
7月前
|
JavaScript 前端开发
必知的技术知识:esm前端模块化
必知的技术知识:esm前端模块化
140 0
|
8月前
|
前端开发 JavaScript 安全
【Web 前端】怎么实现Module模块化?
【5月更文挑战第1天】【Web 前端】怎么实现Module模块化?