はじめに
__CAPGO_KEEP_0__
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-background-task`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/background-task/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
@capgo/capacitor-background-task Capacitor アプリは、同期、キャッシュ更新、分析データの送信、他のバックグラウンドフェッチオペレーションなど、定期的なジョブの登録を許可します。
インストール
「インストール」のセクションnpm install @capgo/capacitor-background-tasknpx cap synciOS セットアップ
「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インポート
「インポート」のセクションimport { BackgroundTask, BackgroundTaskResult } from '@capgo/capacitor-background-task';タスクを定義
「タスクを定義」のセクションモジュールスコープでコールバックを定義し、システムがアプリケーションを起動するとすぐに登録されるようにします。
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; }});スケジュールを登録
「スケジュールを登録」のセクションアプリケーションがバックグラウンドジョブを有効にするのに十分なコンテキストを持っている後、呼び出してください。 registerTaskAsync モジュールスコープでコールバックを定義し、システムがアプリケーションを起動するとすぐに登録されるようにします。
await BackgroundTask.registerTaskAsync(SYNC_TASK, { minimumInterval: 30, requiresNetwork: true,});minimumInterval は分数で表されます。Androidは15分以上の最小値を強制します。iOSは値を最早の開始日として扱い、実行が遅れる可能性があります。
ステータスを確認
「ステータスを確認」のセクションconst status = await BackgroundTask.getStatusAsync();const isRegistered = await BackgroundTask.isTaskRegisteredAsync(SYNC_TASK);const registeredTasks = await BackgroundTask.getRegisteredTasksAsync();
console.log({ status, isRegistered, registeredTasks });テスト実行をトリガー
「テスト実行をトリガー」のセクション開発またはQAでテストトリガーを使用します。登録済みのタスクをすべて即座に呼び出します。
await BackgroundTask.triggerTaskWorkerForTestingAsync();タスクを登録解除
「タスクを登録解除」のセクションawait BackgroundTask.unregisterTaskAsync(SYNC_TASK);__CAPGO_KEEP_0__
iOS 有効期限iOS は、JavaScript の実行が完了する前にバックグラウンドタスクを停止することができます。有効期限イベントをリスンすることで、クリーンアップやチェックポイントが必要な場合に備えてください。
const expiration = await BackgroundTask.addExpirationListener((event) => { console.warn('Background task expired', event.taskName, event.taskId);});
await expiration.remove();React Native バックグラウンドタスク互換性
プラグインは、Capacitor から React Native に移行するアプリ向けに、小さな互換レイヤーを公開しています。コピー react-native-background-task.
import { BackgroundTask } from '@capgo/capacitor-background-task';
BackgroundTask.define(async () => { await fetch('https://api.example.com/sync', { method: 'POST' });});
await BackgroundTask.schedule({ period: 1800,});バックグラウンドスケジューリングは、厳密なタイムアウトではありません。
作業を短く、idempotent にしてください。- Copy to clipboard
- React Native バックグラウンドタスク互換性
- __CAPGO_KEEP_0__を保存しておく
BackgroundTaskResult.Success. - __CAPGO_KEEP_0__に依存してください