”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 简化 SVG 管理:将路径转换为单个 JS 常量文件

简化 SVG 管理:将路径转换为单个 JS 常量文件

发布于2024-11-07
浏览:521

Simplify SVG Management: Convert Paths to a Single JS File of Constants

构建 React.js 应用程序时,有效管理 SVG 图标至关重要。 SVG 提供了响应式设计所需的可扩展性和灵活性,但在大型项目中处理它们可能会变得很麻烦。这就是 svg-path-constants 的用武之地,它是一个 CLI 工具,旨在通过将 SVG 路径转换为可重用常量来简化 SVG 工作流程。

为什么使用 SVG 和常量?

在上一篇文章“React.js 项目中 SVG 图标管理选项的综合比较”中,我讨论了管理 SVG 图标的各种方法,包括内联 SVG、SVG 精灵以及为每个图标使用 React 组件。虽然每种方法都有其优点和缺点,但仍然存在一个挑战:保持 SVG 路径井然有序且可重用。

对 SVG 路径使用常量可以提供较小的包大小和快速的构建时间。

什么是 svg 路径常量?

svg-path-constants 是一个 CLI 工具,可帮助您从 SVG 文件生成常量,从而更轻松地在 React 项目中集成和管理 SVG 图标。它将 SVG 路径转换为 ​​JS 常量,支持灵活的命名约定,并允许自定义输出。

主要特点:

  • 从SVG文件生成常量:快速将SVG路径转换为常量。
  • 灵活的命名约定:支持camelCase、PascalCase、snake_case和SCREAMING_SNAKE_CASE。
  • 可自定义输出:使用自定义模板和文件路径生成常量。
  • 属性转换:自动将 SVG 属性(如不透明度、填充不透明度、描边和填充)转换为路径字符串。
  • 单个或多个输出:根据您的输入结构生成单个输出文件或多个文件。

svg-path-constants 入门

您可以通过 npx:
立即开始使用 svg-path-constants

npx svg-path-constants@latest

或者,您可以全局安装它或作为开发依赖项安装:

npm install -g svg-path-constants
npm install --save-dev svg-path-constants

用法示例

基本用法

假设您在 src/assets/icons 中有 SVG 文件,并且想要在 src/components/Icon/paths.js 中生成常量:

npx svg-path-constants@latest -i src/assets/icons -o src/components/Icon/paths.js

输出示例:

// src/components/Icon/paths.js
export const folderIcon1 = "M10 10 H 90 V 90 H 10 Z"; // Example SVG path
export const folderIcon2 = "M20 20 H 80 V 80 H 20 Z"; // Example SVG path

自定义命名格式

指定不同的命名格式,如 PascalCase:

npx svg-path-constants@latest -i src/assets/icons -o src/components/Icon/paths.js -f PascalCase

输出示例:

// src/components/Icon/paths.js
export const FolderIcon1 = "M10 10 H 90 V 90 H 10 Z"; // Example SVG path
export const FolderIcon2 = "M20 20 H 80 V 80 H 20 Z"; // Example SVG path

使用模板进行输出

使用自定义模板控制命名和文件输出:

npx svg-path-constants@latest -i src/assets/icons -o src/components/Icon/{-2,-1}/{0}.js -t "{1,-3}"

输出示例:

// src/components/Icon/folder/icon1.js
export const folderIcon1 = "M10 10 H 90 V 90 H 10 Z"; // Example SVG path

// src/components/Icon/folder/icon2.js
export const folderIcon2 = "M20 20 H 80 V 80 H 20 Z"; // Example SVG path

处理 SVG 属性

svg-path-constants 可以将 SVG 属性(如不透明度、填充不透明度、描边和填充)转换为路径字符串的组件。

SVG 示例:


    

生成的路径常量:

export const myIcon = "o0.5 O0.8 fff000 F00ff00 M10 10 H 90 V 90 H 10 Z";
  • opacity="0.5" 变为 o0.5
  • fill-opacity="0.8" 变为 O0.8
  • 笔画=“#ff0000”变为fff000
  • fill="#00ff00" 变为 F00ff00

此功能允许您直接在路径字符串中保留基本样式信息,从而保持紧凑且信息丰富的表示形式。

示例:在 React 组件中使用 SVG 路径常量

使用 svg-path-constants 生成 SVG 路径常量后,您可以轻松地将它们集成到您的 React 组件中。这不仅可以保持代码整洁,还可以在应用程序中轻松重用 SVG 路径。

第 1 步:生成 SVG 路径常量

假设您已经运行以下命令来从 SVG 文件生成常量:

npx svg-path-constants@latest -i src/assets/icons -o src/components/Icon/paths.js

此命令生成一个文件 src/components/Icon/paths.js ,其中包含以下常量:

// src/components/Icon/paths.js
export const folderIcon1 = "M10 10 H 90 V 90 H 10 Z"; // Example SVG path
export const folderIcon2 = "M20 20 H 80 V 80 H 20 Z"; // Example SVG path

第 2 步:创建一个 React 组件来渲染 SVG

现在,让我们创建一个 React 组件,使用生成的常量渲染这些 SVG 图标。

import React from 'react';
import { folderIcon1, folderIcon2 } from './paths'; // Import the generated SVG path constants

const parsePathData = (d) => {
    const pathElements = [];
    const pathCommands = d.split(/(o[\d.] |O[\d.] |f[0-9a-fA-F] |F[0-9a-fA-F] )/); // Split by style commands
    let attributes = null;

    pathCommands.forEach((text, i) => {
        const isCommand = Boolean(i % 2);
        if (isCommand) {
            if (!attributes) {
                attributes = {};
            }
            const match = text.match(/^(o([\d.] ))?(O([\d.] ))?(f([0-9a-fA-F] ))?(F([0-9a-fA-F] ))?$/);

            const [, , opacity, , fillOpacity, , stroke, , fill] = match;
            if (opacity) attributes.opacity = opacity;
            if (fillOpacity) attributes["fill-opacity"] = fillOpacity;
            if (stroke) attributes.stroke = `#${stroke}`;
            if (fill) attributes.fill = `#${fill}`;
            return;
        }
        if (text.trim().length) {
            pathElements.push({ ...attributes, d: text });
        }
    });

    return pathElements;
};


const SvgIcon = ({ d, size = 24, color = 'currentColor', ...props }) => {
    const pathElements = parsePathData(d);

    return (
        
            {pathElements.map((attrs, index) => (
                
            ))}
        
    );
};

const IconDemo = () => (
    

SVG Icon Examples

Folder Icon 1

Folder Icon 2

); export default IconDemo;

第 3 步:在您的应用程序中使用该组件

您现在可以在 React 应用程序中的任何位置使用 IconDemo 组件来显示 SVG 图标:

import React from 'react';
import ReactDOM from 'react-dom';
import IconDemo from './components/Icon/IconDemo';

ReactDOM.render(
    
        
    ,
    document.getElementById('root')
);

解释:

  1. parsePathData 函数:

    • 仅当 SVG 文件中有不透明度或多种颜色时才需要。
    • parsePathData 函数处理扩展的 d 属性字符串,提取 o(不透明度)、F(填充颜色)和 f(描边颜色)等命令。
    • 它根据这些命令分割字符串,应用相应的属性,并返回路径元素数组。
  2. SvgIcon 组件:

    • 该组件采用 d 属性字符串,使用 parsePathData 对其进行解析,并渲染 SVG 路径。
    • 该组件允许通过尺寸和颜色等道具进行自定义。
  3. IconDemo 组件:

    • 这是一个演示组件,展示了如何使用具有不同 d 字符串、大小和颜色的 SvgIcon 组件。

接下来是什么?将光栅图像添加到常量

我目前正在开发一个 npm 库,该库将通过在每个生成的常量上方添加光栅图像 (PNG) 作为注释来增强 svg-path-constants。这将直接在代码中提供图标的可视化表示,从而更轻松地识别和管理 SVG 路径。

结论

管理 React 项目中的 SVG 路径并不一定很麻烦。使用 svg-path-constants,您可以保持图标井井有条,代码整洁,工作流程高效。很快,随着即将推出的用于将光栅图像添加到图标注释的库,您将拥有一种更加可视化和直观的方式来管理您的 SVG 资源。

今天尝试 svg-path-constants:

npx svg-path-constants@latest

敬请关注更多更新!

版本声明 本文转载于:https://dev.to/simprl/simplify-svg-management-convert-paths-to-a-single-js-file-of-constants-3fl1?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    The Mystery of "Broken" Two-Phase Template Instantiation in Microsoft Visual C Problem Statement:Users commonly express concerns that Micro...
    编程 发布于2025-03-11
  • 如何使用组在MySQL中旋转数据?
    如何使用组在MySQL中旋转数据?
    在关系数据库中使用mySQL组使用mySQL组进行查询结果,在关系数据库中使用MySQL组,转移数据的数据是指重新排列的行和列的重排以增强数据可视化。在这里,我们面对一个共同的挑战:使用组的组将数据从基于行的基于列的转换为基于列。 Let's consider the following ...
    编程 发布于2025-03-11
  • 如何检查对象是否具有Python中的特定属性?
    如何检查对象是否具有Python中的特定属性?
    方法来确定对象属性存在寻求一种方法来验证对象中特定属性的存在。考虑以下示例,其中尝试访问不确定属性会引起错误: >>> a = someClass() >>> A.property Trackback(最近的最新电话): 文件“ ”,第1行, attributeError:SomeClass实...
    编程 发布于2025-03-11
  • 大批
    大批
    [2 数组是对象,因此它们在JS中也具有方法。 切片(开始):在新数组中提取部分数组,而无需突变原始数组。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    编程 发布于2025-03-11
  • 如何干净地删除匿名JavaScript事件处理程序?
    如何干净地删除匿名JavaScript事件处理程序?
    删除匿名事件侦听器将匿名事件侦听器添加到元素中会提供灵活性和简单性,但是当要删除它们时,可以构成挑战,而无需替换元素本身就可以替换一个问题。 element? element.addeventlistener(event,function(){/在这里工作/},false); 要解决此问题,请考虑...
    编程 发布于2025-03-11
  • 为什么我的CSS背景图像出现?
    为什么我的CSS背景图像出现?
    故障排除:CSS背景图像未出现 ,您的背景图像尽管遵循教程说明,但您的背景图像仍未加载。图像和样式表位于相同的目录中,但背景仍然是空白的白色帆布。而不是不弃用的,您已经使用了CSS样式: bockent {背景:封闭图像文件名:背景图:url(nickcage.jpg); 如果您的html,css...
    编程 发布于2025-03-11
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 A 和表 B,其中表 A 的列数多于表 B。为了合并这些表,同时处理表 B 中缺失的列,请按照以下步骤操作: 确定表 B 中缺失的列,并将它们添加到表的末...
    编程 发布于2025-03-11
  • Java是否允许多种返回类型:仔细研究通用方法?
    Java是否允许多种返回类型:仔细研究通用方法?
    在Java中的多个返回类型:一种误解类型:在Java编程中揭示,在Java编程中,Peculiar方法签名可能会出现,可能会出现,使开发人员陷入困境,使开发人员陷入困境。 getResult(string s); ,其中foo是自定义类。该方法声明似乎拥有两种返回类型:列表和E。但这确实是如此吗...
    编程 发布于2025-03-11
  • 如何使用FormData()处理多个文件上传?
    如何使用FormData()处理多个文件上传?
    )处理多个文件输入时,通常需要处理多个文件上传时,通常是必要的。 The fd.append("fileToUpload[]", files[x]); method can be used for this purpose, allowing you to send multi...
    编程 发布于2025-03-11
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    答案: 在大多数现代编译器中,while(1)和(1)和(;;)之间没有性能差异。编译器: perl: 1 输入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    编程 发布于2025-03-11
  • 为什么使用Firefox后退按钮时JavaScript执行停止?
    为什么使用Firefox后退按钮时JavaScript执行停止?
    导航历史记录问题:JavaScript使用Firefox Back Back 此行为是由浏览器缓存JavaScript资源引起的。要解决此问题并确保在后续页面访问中执行脚本,Firefox用户应设置一个空功能。 警报'); }; alert('inline Alert')...
    编程 发布于2025-03-11
  • 如何克服PHP的功能重新定义限制?
    如何克服PHP的功能重新定义限制?
    克服PHP的函数重新定义限制在PHP中,多次定义一个相同名称的函数是一个no-no。尝试这样做,如提供的代码段所示,将导致可怕的“不能重新列出”错误。 但是,PHP工具腰带中有一个隐藏的宝石:runkit扩展。它使您能够灵活地重新定义函数。 runkit_function_renction_re...
    编程 发布于2025-03-11
  • 为什么PYTZ最初显示出意外的时区偏移?
    为什么PYTZ最初显示出意外的时区偏移?
    与pytz 最初从pytz获得特定的偏移。例如,亚洲/hong_kong最初显示一个七个小时37分钟的偏移: 差异源利用本地化将时区分配给日期,使用了适当的时区名称和偏移量。但是,直接使用DateTime构造器分配时区不允许进行正确的调整。 example pytz.timezone(...
    编程 发布于2025-03-11
  • 为什么不使用CSS`content'属性显示图像?
    为什么不使用CSS`content'属性显示图像?
    在Firefox extemers属性为某些图像很大,&& && && &&华倍华倍[华氏华倍华氏度]很少见,却是某些浏览属性很少,尤其是特定于Firefox的某些浏览器未能在使用内容属性引用时未能显示图像的情况。这可以在提供的CSS类中看到:。googlepic { 内容:url(&#...
    编程 发布于2025-03-11
  • 如何从PHP中的数组中提取随机元素?
    如何从PHP中的数组中提取随机元素?
    从阵列中的随机选择,可以轻松从数组中获取随机项目。考虑以下数组:; 从此数组中检索一个随机项目,利用array_rand( array_rand()函数从数组返回一个随机键。通过将$项目数组索引使用此键,我们可以从数组中访问一个随机元素。这种方法为选择随机项目提供了一种直接且可靠的方法。
    编程 发布于2025-03-11

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3