跳过主要内容
返回插件
@capgo/capacitor-background-task
教程
@capgo/capacitor-background-task

后台任务

在 iOS 和 Android 上使用 Expo 风格的任务注册来安排周期性背景抓取任务

指南

关于背景任务的教程

使用 @capgo/capacitor-background-task

在一个 Capacitor 应用中使用命名任务、持久注册、状态检查、注销和开发触发器来安排周期性背景抓取工作。该插件使用 Android WorkManager 和 iOS BGTaskScheduler。

安装

npm install @capgo/capacitor-background-task
npx cap sync

iOS 设置

添加后台处理支持到 ios/App/App/Info.plist:

<key>UIBackgroundModes</key>
<array>
  <string>processing</string>
</array>
<key>BGTaskSchedulerPermittedIdentifiers</key>
<array>
  <string>app.capgo.backgroundtask.processing</string>
</array>

然后运行:

npx cap sync ios

此插件暴露的内容

  • defineTask - 为一个命名任务定义 JavaScript 回调。
  • registerTaskAsync - 持久化和调度一个周期性任务。
  • unregisterTaskAsync - 取消一个任务。
  • isTaskRegisteredAsync - 检查一个任务的注册状态。
  • getRegisteredTasksAsync - 列出注册的任务名称。
  • getStatusAsync - 检查原生后台任务可用性。
  • triggerTaskWorkerForTestingAsync - 在开发环境下触发已注册的任务。
  • addExpirationListener - 在 iOS 过期任务时做出反应。

示例使用

定义任务在模块范围内,使其在应用程序唤醒时可用:

import { BackgroundTask, BackgroundTaskResult } from '@capgo/capacitor-background-task';

const SYNC_TASK = 'sync-offline-data';

BackgroundTask.defineTask(SYNC_TASK, async () => {
  try {
    await fetch('https://api.example.com/sync', { method: 'POST' });
    return BackgroundTaskResult.Success;
  } catch {
    return BackgroundTaskResult.Failed;
  }
});

await BackgroundTask.registerTaskAsync(SYNC_TASK, {
  minimumInterval: 30,
  requiresNetwork: true,
});

检查状态和注册任务名称:

const status = await BackgroundTask.getStatusAsync();
const tasks = await BackgroundTask.getRegisteredTasksAsync();

console.log({ status, tasks });

触发开发运行:

await BackgroundTask.triggerTaskWorkerForTestingAsync();

取消任务:

await BackgroundTask.unregisterTaskAsync(SYNC_TASK);

平台说明

  • 后台任务的调度是机会主义的,而不是精确的计时器。
  • Android 周期性工作有一个 15 分钟的最小间隔。
  • iOS 将 minimumInterval 视为最早开始的日期,并可能在后面运行。
  • 在物理设备上测试 iOS 后台处理:

全参考

继续使用@capgo/capacitor-background-task

如果您正在使用 使用@capgo/capacitor-background-task 来规划原生插件工作,连接它与 @capgo/capacitor-background-task 查看@capgo/capacitor-background-task中的实现细节 开始 查看开始中的实现细节 Capgo插件目录 为产品工作流程在Capgo插件目录中 Capacitor插件由Capgo 为Capacitor插件的实现细节在Capgo,和 添加或更新插件 为添加或更新插件的实现细节。