指南
关于背景任务的教程
使用 @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 后台处理:
全参考
- GitHub: https://github.com/Cap-go/capacitor-background-task/
- 文档:/docs/plugins/background-task/
继续使用@capgo/capacitor-background-task
如果您正在使用 使用@capgo/capacitor-background-task 来规划原生插件工作,连接它与 @capgo/capacitor-background-task 查看@capgo/capacitor-background-task中的实现细节 开始 查看开始中的实现细节 Capgo插件目录 为产品工作流程在Capgo插件目录中 Capacitor插件由Capgo 为Capacitor插件的实现细节在Capgo,和 添加或更新插件 为添加或更新插件的实现细节。