__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設定」のセクション背景処理モードと許可されたタスクIDを追加し、 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';タスクを定義する
「タスクを定義する」のセクション__CAPGO_KEEP_0__モジュールスコープでコールバックを定義することで、システムがアプリケーションを起動したときにすぐに登録されるようにします。
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 ステータスを確認
ステータスを確認
クリップボードにコピーconst status = await BackgroundTask.getStatusAsync();const isRegistered = await BackgroundTask.isTaskRegisteredAsync(SYNC_TASK);const registeredTasks = await BackgroundTask.getRegisteredTasksAsync();
console.log({ status, isRegistered, registeredTasks });クリップボードにコピー
await BackgroundTask.triggerTaskWorkerForTestingAsync();__CAPGO_KEEP_0__
タスクの登録解除await BackgroundTask.unregisterTaskAsync(SYNC_TASK);iOSの有効期限
タイトル:iOSの有効期限iOSはJavaScriptの実行が完了する前にバックグラウンドタスクを停止することができます。クリーンアップやチェックポイントが必要な場合は、期限切れのイベントをリスンしてください。
const expiration = await BackgroundTask.addExpirationListener((event) => { console.warn('Background task expired', event.taskName, event.taskId);});
await expiration.remove();React Nativeバックグラウンドタスクの互換性
タイトル: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 にしてください。
- __CAPGO_KEEP_0__ が必要な場合にのみ、状態を永続化してください。
BackgroundTaskResult.Success. - ユーザーに表示される期限やアラームに依存してはなりません。
Getting Started から続けてください。
Getting Started から続けてください。Capacitor を使用している場合、 Getting Started から続けてください。 Capacitor のプラグインディレクトリを使用して、 Using @capgo/capacitor-background-task for the native capability in Using @capgo/capacitor-background-task, Capgo Plugin Directory 製品ワークフローについての説明は、Capgo プラグインディレクトリで行います。 Capacitor プラグインは、Capgo によって提供されています。 実装の詳細については、Capacitor プラグインの Capgo を参照してください。 プラグインの追加または更新 実装の詳細については、プラグインの追加または更新を参照してください。 Ionic Enterprise プラグインの代替 製品ワークフローについての説明は、Ionic Enterprise プラグインの代替で行います。