Empezar
Copiar un prompt de configuración con los pasos de instalación y la guía de markdown completa para este plugin.
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 permite que una aplicación Capacitor se registre para tareas periódicas de sincronización, refrescos de caché, entrega de análisis y otras operaciones de recuperación de fondo.
Instalación
Sección titulada “Instalación”npm install @capgo/capacitor-background-tasknpx cap syncConfiguración de iOS
Sección titulada “Configuración de iOS”Agregue el modo de procesamiento de fondo y el identificador de tarea permitida a ios/App/App/Info.plist:
<key>UIBackgroundModes</key><array> <string>processing</string></array><key>BGTaskSchedulerPermittedIdentifiers</key><array> <string>app.capgo.backgroundtask.processing</string></array>Luego ejecute:
npx cap sync iosImportar
Sección titulada “Importar”import { BackgroundTask, BackgroundTaskResult } from '@capgo/capacitor-background-task';Definir una tarea
Sección titulada “Definir una tarea”Define la llamada a función en el ámbito del módulo para que se registre tan pronto como se inicie la aplicación por parte del sistema operativo.
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; }});Registrar El Horario
Sección titulada “Registrar El Horario”Llamar registerTaskAsync después de que tu aplicación tenga suficiente contexto para habilitar el trabajo de fondo.
await BackgroundTask.registerTaskAsync(SYNC_TASK, { minimumInterval: 30, requiresNetwork: true,});minimumInterval dura __CAPGO_KEEP_0__ minutos. Android impone un mínimo de 15 minutos. iOS trata el valor como una fecha de inicio más temprana y puede ejecutarse más tarde.
Ver Estado
Sección titulada “Ver Estado”const status = await BackgroundTask.getStatusAsync();const isRegistered = await BackgroundTask.isTaskRegisteredAsync(SYNC_TASK);const registeredTasks = await BackgroundTask.getRegisteredTasksAsync();
console.log({ status, isRegistered, registeredTasks });Desencadenar una Ejecución de Prueba
Sección titulada “Desencadenar una Ejecución de Prueba”Utilice el desencadenante de prueba en desarrollo o QA. Llama a cada tarea registrada de inmediato.
await BackgroundTask.triggerTaskWorkerForTestingAsync();Deshabilitar una Tarea
Sección titulada “Deshabilitar una Tarea”await BackgroundTask.unregisterTaskAsync(SYNC_TASK);Vencimiento de iOS
Título de la sección “Vencimiento de iOS”iOS puede detener una tarea de fondo antes de que termine su trabajo de JavaScript. Escuche eventos de vencimiento cuando importa la limpieza o el punto de control.
const expiration = await BackgroundTask.addExpirationListener((event) => { console.warn('Background task expired', event.taskName, event.taskId);});
await expiration.remove();Compatibilidad de la tarea de fondo de React Native
Título de la sección “Compatibilidad de la tarea de fondo de React Native”El plugin también expone una pequeña capa de compatibilidad para aplicaciones que migran desde 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,});Notas de producción
Título de la sección “Notas de producción”- La programación de fondo es oportunista, no exacta.
- Mantenga el trabajo corto y idempotente.
- Mantén cualquier estado que necesites antes de regresar
BackgroundTaskResult.Success. - Evita confiar en tareas de fondo para plazos o alarmas visibles para el usuario.