跳过主要内容

Capacitor 插件贡献指南

了解如何有效地贡献 Capacitor 插件的设置、编码标准、测试和文档的全面指南。

马丁·多纳迪厄

马丁·多纳迪厄

内容营销人员

Capacitor 插件贡献指南

Capacitor 通过连接 web 技术与原生设备功能, 跨平台应用开发。 本指南将帮助您:

  • 设置您的环境: 如 Node.js, Xcode, 和 Android Studio are essential.
  • 遵循 Code 规范: 使用 TypeScript, Swift, 和 Kotlin 以一致的命名规范和错误处理方式
  • 进行彻底的测试: 为 JavaScript、iOS 和 Android 编写单元测试以确保可靠性
  • 进行清晰的文档: 使用 JSDoc 和 README 文件以便于采用
  • 提交一个拉取请求: 在贡献之前确保高质量的 code, 测试和文档。

开源项目的详细指南 - 如何贡献

开发环境设置

创建一个合适的开发环境对于高效的插件开发至关重要。一个准备好的设置允许您顺畅地编码、测试和部署您的插件。

您需要的工具和技能

在开始之前,请确保您安装了以下工具:

类别 要求
核心工具 Node.js (LTS), npm 6+, Git
集成开发环境/编辑器 Visual Studio Code 或您喜爱的编辑器
iOS 开发 Xcode, SwiftLint, CocoaPods
Android 开发 Android Studio, Android SDK, JDK

您还应该对 TypeScript confortable,用于 web 开发,以及 Swift (用于 iOS) 或 Java/Kotlin (用于 Android) 的 native 开发任务 [1][2].

设置单元仓库

The Capacitor 插件 这个生态系统依赖于一个单一仓库结构。这一方法确保您的工作从一开始就符合社区标准。

  1. fork 和克隆仓库
    首先,fork Capacitor 插件仓库到 GitHub。然后,克隆您的 forked 仓库:

    git clone https://github.com/your-username/capacitor-plugins.git
    cd capacitor-plugins
    npm install
  2. 安装依赖项和构建
    运行以下命令来安装所需的所有内容并构建插件:

    npm run build
  3. 设置版本控制
    使用特性分支来跟踪您的更改,并保持您的 fork 与上游仓库同步。

准备原生平台

为了进行跨平台开发,您需要配置 iOS 和 Android 环境。

对于 iOS:

  • 从 Mac App Store 下载 Xcode。

  • 使用以下命令安装命令行工具:

    xcode-select --install
  • 使用以下命令安装CocoaPods:

    sudo gem install cocoapods
  • 设置Apple开发者帐户和必要的证书。

  • 使用SwiftLint(可选)来维护code质量。

对于Android:

  • 安装Android Studio以及最新的SDK和一个虚拟设备。
  • 确保您已安装JDK。
  • 在Android Studio中正确配置Android SDK。

一旦这些平台设置完成,您就可以按照已建立的编码实践并深入插件开发。

Code标准指南

现在您的开发环境已设置好,请遵循这些指南来编写易于维护和使用的插件。

风格指南遵从性

Capacitor 插件生态系统 使用工具如 ESLint、Prettier 和 SwiftLint 强制严格的编码标准。以下是一些必需的格式化内容: 组件, 格式变量

(小驼峰式)
(大驼峰式) deviceInfo 插件
工具 BatteryManager 内容
方法 getLanguageCode() (小驼峰式)
常量 MAX_RETRY_COUNT (下划线式)

插件应使用 TypeScript 以获得更好的类型安全性和 ES6+ 特性,如 async/await此外,应遵循 Swift (iOS) 和 Kotlin (Android) 的平台特定编码习惯。

错误和类型管理

跨平台兼容性中,统一的错误处理至关重要。以下是一个示例:

async checkPermissions(): Promise<PermissionStatus> {
  try {
    const result = await this.implementation.checkPermissions();
    return result;
  } catch (error) {
    throw new Error(`Permission check failed: ${error.message}`);
  }
}

类型安全:

  • 针对特定场景使用专注的接口。
  • 为平台特定变异应用联合类型。

Code 文档

好文档是使您的插件易于使用和可访问的关键。遵循这些实践:

  1. API 文档:编写与 @capacitor/docgen. 例如:
/**
 * @description Get the device's current battery level
 * @returns Promise with the battery level percentage
 */
async getBatteryLevel(): Promise<{ level: number }>;
  1. README 结构:包含安装步骤、配置说明、平台特定要求、使用示例和详细的 API 参考信息。

写好的文档确保您的插件易于采用并为更广泛的 Capacitor 社区做出贡献。

sbb-itb-f9944d2

插件测试指南

测试 Capacitor 插件涉及关注几个关键领域以确保平滑的功能和可靠性。

原生桥接测试

原生桥接测试确保JavaScript和原生 code 之间的通信正常。要开始,请使用每个平台的框架设置测试环境。

以下是一个JavaScript侧的 Jest 用于JavaScript侧的单元测试示例:

// Example of a Jest unit test for the JavaScript bridge
describe('DeviceInfo Plugin', () => {
  test('getBatteryLevel returns valid percentage', async () => {
    const result = await DeviceInfo.getBatteryLevel();
    expect(result.level).toBeGreaterThanOrEqual(0);
    expect(result.level).toBeLessThanOrEqual(100);
  });
});

对于原生侧的测试,使用XCTest进行iOS测试,JUnit进行Android测试。以下是Android的示例:

@Test
fun testBatteryLevel() {
    val plugin = DeviceInfo()
    val result = plugin.getBatteryLevel()
    assertTrue(result.level in 0..100)
}

一旦您确认核心桥接功能正常工作,

完整用户工作流程测试

完整插件测试

为了确保您的插件在不同场景下表现良好,测试各种类别: 测试类别
重点区域 集成测试
跨平台功能 资源使用情况和响应时间
安全测试 数据处理和权限检查

对于具有复杂功能的插件,模拟真实世界的用户场景。例如,如果您正在测试DeviceInfo插件,请检查:

  • 在不同网络条件下进行成功上传
  • 准确的进度报告
  • 在大文件传输期间的内存使用

OTA测试 Capgo

Capgo实时更新控制台界面

Capgo的开源工具使其易于部署和快速测试更新。以下是如何使用它:

  1. 设置 更新频道 如开发、测试和生产环境。
  2. 使用 CI/CD 工具自动化部署。
  3. 立即推送更新。
  4. 通过 Capgo.

对于分阶段发布,Capgo 允许您限制更新到少量用户。例如,您可以每 24 小时将新版本推送到 25% 的用户:

// Example configuration for staged rollout
{
  "plugin": "camera-plugin",
  "version": "1.2.0",
  "rollout": {
    "percentage": 25,
    "interval": "24h"
  }
}

这种分阶段的方法通过利用社区反馈在全面发布之前识别问题。

拉取请求流程

一旦您对更改进行了彻底的测试,请按照以下步骤提交您的拉取请求:

拉取请求提交清单

在提交之前,请确保您已覆盖这些关键领域:

分类 需要检查的内容
Code 质量 - 确保 Swift/Kotlin 实现与 web API 一致。
测试 - 为新功能添加单元测试。
- 确认 CI/CD pipeline 检查成功。
文档 - 根据需要更新 README、内联文档和 CHANGELOG。

社区指南

在协作时,遵循以下最佳实践:

  • 快速响应审阅者反馈。
  • 请将讨论聚焦在技术细节上。
  • 使用GitHub的建议功能来提出code的修改。
  • 提交小型、聚焦的pull请求,针对一次特性或问题。

对于更大的修改,建议在提交之前先创建一个问题并讨论你的方法。Capacitor团队依赖GitHub Actions来进行自动检查,所有检查都必须通过才能进行代码审查。

Capgo集成指南

如果你的插件涉及实时更新,请确保在提交之前它与Capgo无缝工作:

  1. 版本控制
    使用清晰的语义版本控制你的插件,并在changelog中记录所有修改。Capgo的系统帮助跟踪版本在用户设备上的采用率。

  2. CI/CD集成
    将Capgo集成到你的CI/CD管道中以自动化更新部署。

  3. 更新监控
    监控部署成功率并确保遵守应用商店的指南。

Summary

为了让您的插件产生实质性的贡献,需要遵循已建立的流程并符合社区标准。这包括遵循Capacitor的编码指南并对您的工作进行彻底的测试。

PR 检查清单强调了高质量提交的必要性。如果您的插件支持实时更新,集成Capgo(如前所述)可以帮助您快速发布更新而不必等待应用商店的批准。

一旦您的 PR 被合并,保持参与并跟踪问题和发布版本更新。与社区保持持续的互动、保持一致的维护和 跟随Capacitor更新 将确保您的插件保持有用和相关。

注意用户反馈并根据需要进行更新。这项持续的努力有助于维护整个生态系统的整体质量并使您的插件对开发者保持价值。

继续阅读Capacitor插件贡献指南

如果您正在使用 Capacitor插件贡献指南 来规划原生插件工作,连接它与 Capgo插件目录 对于产品工作流程在Capgo插件目录中 Capacitor插件由Capgo 对于Capacitor插件由Capgo的实现细节 添加或更新插件 对于添加或更新插件的实现细节 Ionic企业插件替代品 对于产品工作流程在Ionic企业插件替代品中 Capgo原生构建 对于产品工作流程在Capgo原生构建

Capacitor实时更新

当有web层bug时,通过Capgo将修复直接推送到用户端,而不是等待几天的app store审批。用户在后台接收更新,而原生层的更改仍然在正常审批路径中

立即开始

最新博客文章

Capgo 为您提供创建真正专业的移动应用所需的最佳见解。