十二月第22讲:巧用mask属性创建一个纯CSS图标库

server/2024/12/28 3:13:42/

(Scalable Vector Graphics,可缩放矢量图形)是一种基于 XML 的图像格式,用于定义二维图形。与传统的位图图像(如 PNG 和 JPG)不同,SVG 图像是矢量图形,可以在任何尺寸下保持清晰度,不会失真。

我们将 SVG 代码转换为 data URI,然后在 CSS 中使用,这样我们可以避免多个 HTTP 请求;另一方面,我们使用 mask 来设置 SVG 来作为元素蒙版的图像,然后通过设置元素的 background-color 就可以控制 SVG 显示的颜色。

通过以上两个要素结合,我们就可以创建一个纯CSS图标库:它能通过只设置 class name,就让元素显示出相对应的图标和颜色。

创建图标库

1. 将svg图标对应到class

这里需要注意的是:

  1. 要确保我们的 SVG 图标是单色的
  2. 使用 CSS 变量存储 SVG,有便于减少我们的代码,毕竟 mask 是一个现代浏览器才支持的属性,需要我们设置不同浏览器前缀
 
.weiz-icon-web {
--url: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cg fill='none'%3E%3Crect width='40' height='32' x='4' y='8' stroke='%23000' stroke-linejoin='round' stroke-width='4' rx='3'/%3E%3Cpath stroke='%23000' stroke-width='4' d='M4 11a3 3 0 0 1 3-3h34a3 3 0 0 1 3 3v9H4z'/%3E%3Ccircle r='2' fill='%23000' transform='matrix(0 -1 -1 0 10 14)'/%3E%3Ccircle r='2' fill='%23000' transform='matrix(0 -1 -1 0 16 14)'/%3E%3C/g%3E%3C/svg%3E");
}
.weiz-icon-code {
--url: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='m16 2l5 5v14.008a.993.993 0 0 1-.993.992H3.993A1 1 0 0 1 3 21.008V2.992C3 2.444 3.445 2 3.993 2zm1.657 10L14.12 8.464L12.707 9.88L14.828 12l-2.12 2.121l1.413 1.415zM6.343 12l3.536 3.536l1.414-1.415L9.172 12l2.12-2.121L9.88 8.464z'/%3E%3C/svg%3E");
}
/*其他的省略,可根据需要自行添加*/

2. 设置公共样式

利用变量来存储颜色,后续我们可以利用修改变量的值来控制图标的颜色

 
:root {
--weiz-icon-color: #3C3C43;
}
.weiz-icon {
display: inline-block;
background-color: var(--weiz-icon-color);
width: 16px;
height: 16px;
mask: var(--url) no-repeat center center;
-webkit-mask: var(--url) no-repeat center center;
mask-size: cover;
-webkit-mask-size: cover;
}

3. 设置多种颜色

 
.weiz-icon.main {
--weiz-icon-color: var(--weiz-primary-color);
}
.weiz-icon.white {
--weiz-icon-color: #FFFFFF;
}
.weiz-icon.gray {
--weiz-icon-color: #3C3C43C7;
}
/* 暗黑模式下自动适应 */
.dark {
--weiz-icon-color: #FFFFF5DB;
.weiz-icon.gray {
--weiz-icon-color: #EBEBF599;
}
}

4. 设置多种尺寸

 
.weiz-icon.m {
width: 12px;
height: 12px;
}
.weiz-icon.l {
width: 24px;
height: 24px;
}
.weiz-icon.xl {
width: 32px;
height: 32px;
}
.weiz-icon.xxl {
width: 40px;
height: 40px;
}
.weiz-icon.xxxl {
width: 48px;
height: 48px;
}

应用

相关文章:
https://www.lofter.com/shareblog/mmmf5dfg/
https://www.lofter.com/favblog/mmmf5dfg/
https://www.lofter.com/shareblog/mmmf5dfg
https://www.lofter.com/favblog/mmmf5dfghttps://book.qq.com/book-search/%E5%90%8D%E4%BC%98%E9%A6%86%E7%BD%91%E3%80%9023Y4.com%E3%80%91?c23a
https://book.qq.com/book-search/%E6%B5%B7%E8%A7%92%E7%A4%BE%E5%8C%BA%E3%80%9023Y4.com%E3%80%91?c23b
https://book.qq.com/book-search/%E8%89%B3%E6%AF%8D%E7%BD%91%E8%BF%9B%E3%80%9023Y4.com%E3%80%91?c23c
https://book.qq.com/book-search/%E6%9E%9C%E5%86%BB%E4%BC%A0%E5%AA%92%E3%80%9023Y4.com%E3%80%91?c23d
https://book.qq.com/book-search/%E6%9E%9C%E5%86%BB%E4%BC%A0%E5%AA%92%E8%BF%9B23Y4.com%E7%9C%8B?c23e
https://book.qq.com/book-search/%E6%80%A7%E5%B7%B4%E5%85%8B%E8%BF%9B%E3%80%9023Y4.com%E3%80%91?c23f
https://book.qq.com/book-search/%E7%88%B1%E5%A8%81%E5%A5%B6%E7%BD%91%E3%80%9023Y4.com%E3%80%91?c23g
https://book.qq.com/book-search/%E7%A6%81%E6%BC%AB%E5%A4%A9%E5%A0%82%E3%80%9023Y4.com%E3%80%91?c23h
https://book.qq.com/book-search/%E6%92%B8%E6%92%B8%E7%A4%BE%E7%BD%91%E3%80%9023Y4.com%E3%80%91?c23i
https://book.qq.com/book-search/%E6%8A%96%E9%98%B4%E4%B8%8B%E8%BD%BD%E3%80%8A23Y4.com%E3%80%8B?c23i
https://book.qq.com/book-search/%E6%8A%96%E9%98%B4%E7%BD%91%E7%AB%99%E3%80%9023Y4.com%E3%80%91?c23k
https://book.qq.com/book-search/%E4%B9%85%E4%B9%85%E7%83%AD%E7%9C%8B%E3%80%9023Y4.com%E3%80%91?c23l
https://book.qq.com/book-search/%E4%B9%85%E4%B9%85%E7%83%AD%E8%BF%9B%E3%80%9023Y4.com%E3%80%91?c23m
https://book.qq.com/book-search/%E6%92%B8%E6%92%B8%E7%A4%BE%E8%BF%9B%E3%80%9023Y4.com%E3%80%91?c23n
https://book.qq.com/book-search/%E4%B8%8B%E8%BD%BD%E6%8A%96%E9%98%B4%E3%80%9023Y4.com%E3%80%91?c23o
<i class="weiz-icon l weiz-icon-web white"></i>

效果如图:

image

真实案例请查看:

扩展

推荐一个 SVG 图标网站:。找到自己想要的图标后,点击图标,选择下方的 URL 复制即可。

image


http://www.ppmy.cn/server/153791.html

相关文章

C#关键字volatile

文章目录 一、 基本概念二、可见性问题没有 volatile 关键字的情况使用 volatile 关键字后的可见性保证 三、防止指令重排序指令重排序的概念volatile 防止指令重排序的原理 四、使用场景示例生产者 - 消费者模式示例 五、注意事项性能影响不能替代锁机制 一、 基本概念 在 C# …

2024年中最新!鸿蒙4.2成功开启无线调试

前言 鸿蒙4.2支持“开发人员选项”&#xff0c;但根本没有“无线调试”的按钮可以选&#xff0c;只有USB调试和ADB。 无法使用Shizuku&#xff0c;也无法安装VMOS。 是否能开启“无线调试” 用不了&#xff0c;但是可以用电脑连接手机&#xff0c;打开ADB调试&#xff0c;然…

C++程序设计例题——第三章程序控制结构

第三章 程序控制结构 第三章程序控制结构&#xff1a;3.1使用cin和cout输入输出数据3.2计算三角形面积3.3输入成绩&#xff0c;将成绩分类3.4四个整数排序3.5输入某天日期&#xff0c;自动输出第二天日期3.6输入月份和日期&#xff0c;得到星座3.7求和&#xff1a;1……1003.9判…

Unity 战斗系统中角色UI血条设计

1:如何选取技术方案 Unity战斗系统中&#xff0c;每个角色经常会有血条与昵称。如何架构设计才高效&#xff0c;我们列举一些常用的做法: onGUI来做昵称与血条;3D世界中创建一个3D物体来做血条与昵称,然后让血条与昵称对着摄像机;基于UGUI/NGUI单独做血条与昵称的UI节点&#…

使用 Python 操作 Excel 表格

在Python中操作Excel表格&#xff0c;你可以使用几个流行的库&#xff0c;比如openpyxl、pandas和xlrd/xlwt。下面我会分别介绍这些库的基本用法。 1. 使用 openpyxl openpyxl 是一个用来读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。 安装&#xff1a; pip install ope…

芯片Tapeout power signoff 之IR Drop Redhawk Ploc文件格式及其意义

数字IC后端工程师在芯片流程最后阶段都会使用redhawk或voltus进行设计的IR Drop功耗signoff分析。必须确保静态&#xff0c;动态ir drop都符合signoff标准。 在做redhawk ir drop分析前&#xff0c;我们需要提供一个redhawk ploc供电点坐标。 数字IC设计后端实现前期预防IR D…

重温设计模式--10、单例模式

文章目录 单例模式&#xff08;Singleton Pattern&#xff09;概述单例模式的实现方式及代码示例1. 饿汉式单例&#xff08;在程序启动时就创建实例&#xff09;2. 懒汉式单例&#xff08;在第一次使用时才创建实例&#xff09; 单例模式的注意事项应用场景 C代码懒汉模式-经典…

聊聊volatile的实现原理?

在 Java 并发编程中&#xff0c;有 3 个最常用的关键字&#xff1a;synchronized、ReentrantLock 和 volatile。 虽然 volatile 并不像其他两个关键字一样&#xff0c;能保证线程安全&#xff0c;但 volatile 也是并发编程中最常见的关键字之一。例如&#xff0c;单例模式、Co…