”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 使用 Svelte 创建独立小部件:我的旅程和解决方案

使用 Svelte 创建独立小部件:我的旅程和解决方案

发布于2024-08-19
浏览:885

在过去的几个月里 在过去的几个月里,我的任务是确定如何为我的全职工作编写和管理独立的小部件。虽然确保它们正常运行相对简单,但我很快意识到维护它们完全是一个不同的挑战

考虑到这一点,我在业余时间开始了一个业余项目并将其开源。这使我能够分享我的见解和策略,帮助我确保小部件的质量。

我最初是怎么做的?

由于我的小部件需要高水平的反应性,因此我严重依赖 Svelte 组件 API 并使用 Rollup 进行捆绑。 “这很简单直接,直到我遇到了以下问题:

  • 随着时间的推移,我未使用的 CSS 不断增加,而且我也不确定是否只捆绑了所需组件的 CSS。

  • 如果没有严格的输入,很难通过小部件处理 JavaScript。由于我不得不分享一些像 jwt 解码和身份验证这样的实用程序,它很快就变得一团糟。

我怎么改的呢?

我开始考虑如何建立一些默认值,更重要的是,集成一个类型系统。这导致了我的业余项目 svelte-standalone 的创建。

svelte-standalone 的目标是:

  • 确保 CSS 压缩良好,并在捆绑时删除未使用的 CSS。
  • 确保选择的类型系统在我的所有应用程序上得到良好支持和重用。

注意:选择的类型系统是 TypeScript。

  • 确保单元和集成测试。
  • 确保我可以在汇总解析之前和之后直观地检查我的小部件。

我是如何实现这一切的?

在确保 TypeScript 与 Rollup 插件和 Svelte 预处理器的兼容性之后,我退后一步,将我的项目分解为关键步骤。基本上我有:

  1. A .svelte.
  2. 一个 embed.js 文件,负责启动 .svelte 文件的实例并将其添加到 body。

从此我注意到我的嵌入文件基本上是在我所有小部件上复制的默认文件并开始生成它们。因此,我能够使用 codegen 工具根据我的精简文件和我在整个应用程序中处理类型的愿望生成 3 个文件:

  1. declaration.d.ts - 使我可以直接导入我的 svelte 组件并使用 SvelteComponent 类型包装它,因此我默认将我的 svelte 组件转为强类型。
  2. types.ts - 使我可以根据declaration.d.ts.
  3. 声明的道具编写defaultConfig
  4. embed.ts - 以标准方式为我的所有小部件启用我的组件的启动/停止!

瞧!这种方法解决了我的类型系统问题并提高了我的小部件的可维护性。

我如何应对 CSS 挑战:

我面临的与 CSS 相关的主要挑战是:如何轻松地清除和缩小 CSS?如何编写既易于协作又易于集成到不同环境中的 CSS?

解决方案非常简单:只需使用 Tailwind CSS。
Creating Standalone Widgets with Svelte: My Journey and Solutions

通过这种方法,我发现了以下好处:

  • 不再有冲突的样式:使用 Tailwind 让我不再担心样式冲突。例如,在处理严重依赖 Bootstrap 的遗留应用程序时,我只需向我的小部件应用一个前缀和一个重要标志,冲突就得到了解决。

  • 无缝集成:将我的小部件导入另一个 Tailwind 应用程序时,我可以轻松省略某些 Tailwind 指令以减少我的包大小。

  • 轻松清除和缩小:缩小变得简单,使用 Tailwind 的内置 PurgeCSS,我只需要为每个小部件正确配置内容标志即可。这确保了最终捆绑包中仅包含必要的样式。

我如何解决测试问题?

我在确保对我的小部件进行全面测试方面面临挑战,包括单元测试、集成测试和可视化测试。

我的主要目标是在使用 Rollup 处理组件之前和之后可视化它们。为了实现这一目标,我采取了以下步骤:

  • 严格类型故事书:我根据我的declaration.d.ts和types.ts文件实现了严格类型故事书。这使得自动为我的每个小部件生成默认故事变得很方便。

  • Vite集成:我使用Vite在Svelte路由上加载捆绑的组件。基于我的 TypeScript 文件生成默认路由组件也很方便。

仅此而已!我衷心感谢一些反馈!另外,请查看 svelte-standalone。

无论您有疑问、建议还是疑虑,请随时与我联系!

版本声明 本文转载于:https://dev.to/brenoliradev/how-to-create-widgets-using-svelte-1gep?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • FCS API 与 Insight Ease:比特币 API 服务的简单比较
    FCS API 与 Insight Ease:比特币 API 服务的简单比较
    如果您热衷于比特币 API,那么选择正确的 API 非常重要。特别是如果您是开发人员、金融分析师或经营一家金融科技公司。您会听到的两个流行名称是 FCS API 和 Insight Ease。但哪一个更好呢?让我们仔细观察一下它们的比较,特别是当涉及到加密货币实时汇率 API、加密货币 API 交...
    编程 发布于2024-11-02
  • 如何在不修改HTML的情况下用JavaScript监听表单提交事件?
    如何在不修改HTML的情况下用JavaScript监听表单提交事件?
    在 JavaScript 中监听表单提交事件而不修改 HTML在本文中,我们解决了在不修改 HTML 的情况下监听表单提交事件的常见挑战必须修改 HTML 代码。我们不依赖 HTML 中的 onClick 或 onSubmit 属性,而是提供纯 JavaScript 解决方案。为了实现这一点,我们利...
    编程 发布于2024-11-02
  • Document.getElementById 与 jQuery $():主要区别是什么?
    Document.getElementById 与 jQuery $():主要区别是什么?
    Document.getElementById vs jQuery $():比较分析深入研究 Web 开发领域时,了解普通版本之间的细微差别JavaScript 和 jQuery 可能至关重要。本文研究了两个看似相同的代码片段之间的细微差别:var contents = document.getEl...
    编程 发布于2024-11-02
  • 在 Java 中使用方法和变量句柄进行运行时对象访问和操作
    在 Java 中使用方法和变量句柄进行运行时对象访问和操作
    反射和方法/var 句柄是 Java 中的两个强大功能,允许开发人员在运行时访问和操作对象。然而,它们在访问和处理对象的方式上有所不同。 让我们看一个如何使用反射来访问类中方法的示例。我们将从一个名为“MyClass”的简单类开始,它有一个私有字符串变量和该变量的 getter 方法。为了创建这个对...
    编程 发布于2024-11-02
  • 如何在 Python 中使用内置函数验证 IP 地址?
    如何在 Python 中使用内置函数验证 IP 地址?
    Python 中的 IP 地址验证验证 IP 地址的有效性是编程中的常见任务。从用户处接收字符串形式的 IP 地址时,必须对其进行验证,以确保它们符合正确的格式和结构。要在 Python 中有效验证 IP 地址,请考虑以下方法:无需手动解析 IP 地址,而是利用套接字模块中的内置 inet_aton...
    编程 发布于2024-11-02
  • 我需要学习编程方面的帮助
    我需要学习编程方面的帮助
    您好,我是一名系统工程专业的学生,​​我觉得我在课程中学到的编程知识不多。我想自学,因为我对这个话题非常感兴趣。这就是我在这个网站上向了解编程的人寻求帮助的原因。如果有人知道学习编程的最佳课程,从基础开始并进步到更专业的水平,那将会有很大的帮助。 我感兴趣的语言: Java JavaScript P...
    编程 发布于2024-11-02
  • 如何将 gorm.Model 集成到具有日期时间支持的 Protocol Buffer 定义中?
    如何将 gorm.Model 集成到具有日期时间支持的 Protocol Buffer 定义中?
    将 gorm.Model 集成到 Protocol Buffer 定义中将 gorm 的 gorm.Model 字段集成到 protobuf 定义中时,由于 proto3 中缺乏日期时间支持,出现了挑战。本文探讨了此问题的解决方案。ProtoBuf 字段类型映射CreatedAt、UpdatedAt...
    编程 发布于2024-11-02
  • 修补您的 Discord 活动的网络请求,以实现顺利的 CSP 合规性
    修补您的 Discord 活动的网络请求,以实现顺利的 CSP 合规性
    通过Discord运行Discord活动时,您可能会遇到内容安全策略(CSP)问题。您可以通过确保网络请求遵循 Discord 代理 规则来修复这些问题。 这可以手动完成...或者你可以让@robojs/patch处理它。 什么是CSP? 内容安全策略 (CSP) 是一种安全标准,...
    编程 发布于2024-11-02
  • 推荐项目:删除课程表查看数据
    推荐项目:删除课程表查看数据
    LabEx 的这个项目释放了数据库管理的力量,提供了在数据库中创建和操作视图的全面学习体验。无论您是崭露头角的数据库管理员还是经验丰富的开发人员,该项目都提供了宝贵的机会来增强您的技能并获得对数据管理世界的实际见解。 深入了解基础知识 在这个项目中,您将踏上了解数据库中视图的核心概念...
    编程 发布于2024-11-02
  • 模拟网络请求变得容易:集成 Jest 和 MSW
    模拟网络请求变得容易:集成 Jest 和 MSW
    Writing unit tests that involve mocking or stubbing API calls can feel overwhelming—I’ve been there myself. In this article, I’ll guide you through a ...
    编程 发布于2024-11-02
  • 使用 Javascript 的哈希映射
    使用 Javascript 的哈希映射
    介绍 哈希映射(Hash Map),也称为哈希表(Hash Table),是一种实现关联数组抽象数据类型的数据结构,是一种可以将键映射到值的结构。 它使用哈希函数来计算存储桶或槽数组的索引,从中可以找到所需的值。 哈希映射的主要优点是它的效率。插入新的键值对、删除键值对以及查...
    编程 发布于2024-11-02
  • HTPX 简介:适用于 JavaScript 和 Node.js 的轻量级多功能 HTTP 客户端
    HTPX 简介:适用于 JavaScript 和 Node.js 的轻量级多功能 HTTP 客户端
    作为开发人员,我们的 Web 应用程序通常需要一个可靠且高效的 HTTP 客户端,无论我们是在浏览器中使用 JavaScript 还是在服务器端使用 Node.js 进行构建。这就是我创建 HTPX 的原因——一个强大的、轻量级的解决方案,旨在简化 HTTP 请求,同时为现代开发提供一系列功能。 在...
    编程 发布于2024-11-02
  • 使用自然语言通过法学硕士生成简单的 Python GUI .... 在不到几分钟的时间内
    使用自然语言通过法学硕士生成简单的 Python GUI .... 在不到几分钟的时间内
    Thought that building Python GUIs took hours of tedious coding? Welcome to an exciting new era! Not only can tools like Github Copilot help with code ...
    编程 发布于2024-11-02
  • Dev、Oops 和 WEBAPP 故事
    Dev、Oops 和 WEBAPP 故事
    作为 DevOps 专业人员开发桌面 Web 应用程序感觉就像在广阔而复杂的海洋中航行。随着技术融合,Web、桌面和基于云的应用程序之间的界限变得模糊,迫使 DevOps 深入传统上由前端占据的领域 终端开发商。选择正确的框架变得至关重要,但挑战往往在于筛选当今可用的众多选项。例如,Vite、Rea...
    编程 发布于2024-11-02
  • 释放您的 Django 潜力:适合 4 人的项目创意和资源
    释放您的 Django 潜力:适合 4 人的项目创意和资源
    Django 时事通讯 - 2024 年 10 月 Django 简介和项目想法 如果您希望开始使用 Django 或提高自己的技能,请考虑以下一些宝贵的资源和项目想法: Django 项目想法 对于那些想要尝试或构建自己的作品集的人来说,Djang...
    编程 发布于2024-11-02

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

Copyright© 2022 湘ICP备2022001581号-3