Project Icon

eslint-plugin-boundaries

确保软件架构边界的完整性

此插件通过检查项目中的文件夹、文件结构及其依赖关系,确保遵守软件架构的边界规则。支持检测 import、require、exports 和动态导入,还可配置检查其他 AST 节点。推荐与 eslint-plugin-import 配合使用。主要功能包括确认允许的元素类型、外部模块、私有元素和入口点规则等。支持 TypeScript 和 Eslint v9 及以上版本。

项目介绍:eslint-plugin-boundaries

项目概览

eslint-plugin-boundaries 是一个用于确保软件架构边界被尊重的 ESLint 插件。正如著名软件工程师 Robert C. Martin 所说,软件架构是一门划定边界的艺术。这些边界将软件元素彼此分开,并限制它们之间的相互了解。eslint-plugin-boundaries 通过检查文件夹和文件结构以及它们之间的依赖关系,确保您的项目元素符合这些架构边界。

值得注意的是,该插件并不替代 eslint-plugin-import,反而建议两者结合使用以获得更好的代码结构管理。

功能和特点

  • 多种导入声明支持:不仅检查 import 语句,还可以分析 requireexports 和动态导入。它还可配置检查其他 AST 节点。

  • 元素类型设定:您需要先定义项目中的元素类型,然后插件将根据这些类型识别每个文件,并检查元素之间的依赖关系是否被允许。

  • 预定义配置:插件提供了 "recommended" 和 "strict" 两种预定义配置,用户可以根据项目现状逐步进行重构。

  • 自定义规则设置:用户可以通过规则配置,定义哪些元素能够作为其他元素的依赖,以及这些依赖关系的具体要求。

安装和使用

要使用 eslint-plugin-boundaries,首先通过 npm 安装:

npm install --save-dev eslint eslint-plugin-boundaries

然后在 eslint.config.js 中激活插件并使用其预定义配置:

import boundaries from "eslint-plugin-boundaries";

export default [
  {
    plugins: {
      boundaries,
    },
    rules: {
      ...boundaries.configs.recommended.rules,
    }
  }
];

配置指南

设置插件时,您需要定义项目的元素类型模式,这将决定文件和依赖的检查规则。

export default [{
  settings: {
    "boundaries/elements": [
      {
        type: "helpers",
        pattern: "helpers/*"
      },
      {
        type: "components",
        pattern: "components/*"
      },
      {
        type: "modules",
        pattern: "modules/*"
      }
    ]
  }
}]

插件允许高度定制化的配置来识别和控制项目内部的依赖关系。通常,您可以允许或禁止某种类型的元素进行特定的导入,并定义特定情况下的错误信息。

规则概览

  • 允许元素类型规则:控制项目元素之间允许的依赖关系。
  • 允许外部模块规则:检查各类型元素导入外部模块的合法性。
  • 私有元素规则:防止外部元素调用另一个元素的私有子元素。
  • 入口点规则:确保元素只能从另一个元素的指定入口文件进行导入。

高级特性

  • TypeScript 支持:可通过结合 @typescript-eslint/eslint-plugin 使用于 TypeScript 项目中。

  • 调试模式:插件提供调试模式,帮助在配置过程中检测文件及导入的分析信息。

贡献指南

项目欢迎所有贡献者,并提供了详细的贡献和行为准则,以便社区成员进行贡献和交流。

许可证

eslint-plugin-boundaries 使用 MIT 许可证,具体信息请查看 LICENSE 文件。

通过使用 eslint-plugin-boundaries,开发者可以更好地管理项目中的模块和依赖关系,提高项目的架构质量和可维护性。这个工具不仅增强了代码的清晰度和一致性,还帮助团队更容易地遵循既定的设计模式和软件架构原则。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

稿定AI

稿定设计 是一个多功能的在线设计和创意平台,提供广泛的设计工具和资源,以满足不同用户的需求。从专业的图形设计师到普通用户,无论是进行图片处理、智能抠图、H5页面制作还是视频剪辑,稿定设计都能提供简单、高效的解决方案。该平台以其用户友好的界面和强大的功能集合,帮助用户轻松实现创意设计。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号