Saltar al contenido

Inicio

Ventana de terminal
npm install @capgo/capacitor-webview-crash
npx cap sync
import { WebViewCrash } from '@capgo/capacitor-webview-crash';

Adjunte oyentes lo antes posible en el arranque de su aplicación para que el runtime recuperado pueda reaccionar antes de que los usuarios continúen navegando:

import { WebViewCrash } from '@capgo/capacitor-webview-crash';
await WebViewCrash.addListener('webViewRestoredAfterCrash', async (info) => {
console.log('Recovered after a WebView crash', info);
// Rehydrate critical state, reopen the correct screen, or prompt the user to retry.
await WebViewCrash.clearPendingCrashInfo();
});
await WebViewCrash.addListener('webViewRestoredAfterRestart', async (info) => {
console.log('Recovered after a native WebView restart', info);
await WebViewCrash.clearPendingCrashInfo();
});
const pending = await WebViewCrash.getPendingCrashInfo();
// Note: the listener callback may have already cleared the pending marker.
if (pending.value) {
console.log('Pending crash or restart marker', pending.value);
}

Establecer opciones de reinicio en capacitor.config.ts para que la decisión permanezca en nativo code incluso cuando el runtime de JavaScript ha fallado o no se ha cargado aún:

import type { CapacitorConfig } from '@capacitor/cli';
import type { WebViewCrashPluginConfig } from '@capgo/capacitor-webview-crash';
const webViewCrash: WebViewCrashPluginConfig = {
// Enabled by default. Keep this on for long-running apps.
restartOnCrash: true,
// Use a 5-field cron schedule in the device local timezone.
// Do not combine restartCron with an active restartIntervalMs.
restartCron: '0 3 * * *',
// Optional delay before restarting after a crash.
restartAfterCrashDelayMs: 0,
};
const config: CapacitorConfig = {
plugins: {
WebViewCrash: webViewCrash,
},
};
export default config;

Usar restartIntervalMs para aplicaciones siempre encendidas donde los usuarios pueden mantener la misma WebView abierta durante días: pantallas de kiosk, tableros de control, escáneres de almacén, terminales de caja, tabletas de flota y señalización digital. Usar restartCron para reinicios de reloj de pared como 0 3 * * * para un reinicio diario a las 03:00 en la zona horaria local del dispositivo. Los reinicios programados escriben un marcador pendiente con reason: 'periodicRestart'luego Android recrea la actividad del host y iOS reconstruye la vista del puente Capacitor para crear un nuevo WKWebView se crea desde el code nativo.

Elige un intervalo o un horario cron que tu producto pueda tolerar. restartCron admite *, listas, rangos y pasos. No configures ambos horarios al mismo tiempo: la inicialización nativa lanza un error de configuración fatal cuando restartCron está configurado y restartIntervalMs es mayor que 0. Un reinicio crea un entorno de tiempo de ejecución JavaScript fresco, por lo que persiste los eventos programados, el estado de formulario no guardado y el estado de navegación actual antes de usar horarios agresivos.

Llamar restartWebView() cuando el entorno de ejecución JavaScript actual decide que el navegador nativo debe ser reemplazado de manera proactiva, por ejemplo, después de un flujo de trabajo pesado en memoria o antes de entrar en una sesión inalcanzable prolongada:

await WebViewCrash.restartWebView();

El método escribe un marcador pendiente con reason: 'manualRestart', resolves the current call, then asks native code to create a fresh WebView. Android recreates the host activity. iOS rebuilds the Capacitor bridge view so a new WKWebView Android recrea la actividad del host. iOS reconstruye la __CAPGO_KEEP_1__ vista de puente para crear una nueva

API overview

API overview

Sección titulada “getPendingCrashInfo” null Devuelve el marcador de crash o reinicio nativo almacenado, o

const pending = await WebViewCrash.getPendingCrashInfo();
if (pending.value) {
console.log(pending.value.platform, pending.value.reason);
}

clearPendingCrashInfo

Copiar a portapapeles

Elimina el marcador almacenado después de que se haya completado su manejo de recuperación.

await WebViewCrash.clearPendingCrashInfo();

Crea un marcador de crash falso para que QA y depuración local puedan ejercer el camino de recuperación sin hacer que se caiga una WebView real.

const simulated = await WebViewCrash.simulateCrashRecovery();
console.log(simulated.value);

Almacena un marcador de reinicio manual y le pide a code nativo que cree una WebView fresca.

await WebViewCrash.restartWebView();
  • Android almacena metadatos de crash desde onRenderProcessGoneincluyendo didCrash y cuando la plataforma los proporciona. rendererPriorityAtExit iOS almacena metadatos de errores de la plataforma.
  • y agrega el estado de la aplicación actual cuando esté disponible. webViewWebContentProcessDidTerminate Reinicios manuales y programados crean una WebView fresca. Android recrea la actividad del host; iOS reconstruye la vista de la puente __CAPGO_KEEP_0__.
  • Manual and scheduled restarts create a fresh WebView. Android recreates the host activity; iOS rebuilds the Capacitor bridge view.
  • ; reinicios manuales utilizan reason: 'periodicRestart'La web no detecta errores de renderizado reales. La implementación web solo simula el comportamiento con almacenamiento local. reason: 'manualRestart'.
  • Referencia de tipos

Título de la sección “Referencia de tipos”

Título de la sección “PendingCrashInfoResult”

PendingCrashInfoResult

Copiar a portapapeles
export interface PendingCrashInfoResult {
/**
* Stored crash or restart metadata, or `null` when no marker is pending.
*/
value: WebViewCrashInfo | null;
}
export interface WebViewCrashPluginConfig {
/**
* Restart the WebView from native code when the renderer process dies.
*
* @default true
*/
restartOnCrash?: boolean;
/**
* Fixed native interval, in milliseconds, for proactively replacing long-running WebViews.
*
* Set to `0` to disable interval restarts. Do not combine an active interval
* with `restartCron`; native initialization fails fast when both schedules are configured.
*
* @default 0
*/
restartIntervalMs?: number;
/**
* Cron schedule for proactively replacing long-running WebViews.
*
* Uses standard 5-field cron syntax in the device local timezone:
* `minute hour day-of-month month day-of-week`.
*
* Examples:
* - `0 3 * * *` restarts every day at 03:00.
* - `0,30 * * * *` restarts every 30 minutes.
*
* Do not combine this with an active `restartIntervalMs`; native initialization
* fails fast when both schedules are configured.
*/
restartCron?: string;
/**
* Delay, in milliseconds, before restarting after a crash.
*
* @default 0
*/
restartAfterCrashDelayMs?: number;
}
export interface WebViewCrashInfo {
/**
* Platform that detected and stored the marker.
*/
platform: WebViewCrashPlatform;
/**
* Unix timestamp in milliseconds for when the marker was written.
*/
timestamp: number;
/**
* ISO-8601 version of `timestamp`.
*/
timestampISO: string;
/**
* Platform-specific reason for the crash or restart marker.
*/
reason: WebViewCrashReason;
/**
* Last known WebView URL when the marker was written.
*/
url?: string;
/**
* Android-only hint from `RenderProcessGoneDetail.didCrash()`.
*/
didCrash?: boolean;
/**
* Android-only renderer priority reported at exit.
*/
rendererPriorityAtExit?: number;
/**
* iOS-only application state captured when the WebView process died.
*/
appState?: WebViewCrashAppState;
}
export type WebViewCrashPlatform = 'android' | 'ios' | 'web';
export type WebViewCrashReason =
| 'renderProcessGone'
| 'webContentProcessDidTerminate'
| 'periodicRestart'
| 'manualRestart'
| 'simulated';
export type WebViewCrashAppState = 'active' | 'inactive' | 'background' | 'unknown';

This page is generated from the plugin’s src/definitions.tsRe-ejecuta la sincronización cuando los archivos públicos API cambian en la rama upstream.

Si estás utilizando Getting Started para planificar el comportamiento de medios y interfaces nativos, conecta con Usando @capgo/capacitor-webview-crash para la capacidad nativa en Usando @capgo/capacitor-webview-crash, Usando @capgo/capacitor-live-activities para la capacidad nativa en Usando @capgo/capacitor-live-activities, @capgo/capacitor-live-activities para el detalle de implementación en @capgo/capacitor-actividades-en-vivo, Usando @capgo/capacitor-reproductor-de-videos para la capacidad nativa en Usando @capgo/capacitor-reproductor-de-videos, y @capgo/capacitor-reproductor-de-videos para el detalle de implementación en @capgo/capacitor-reproductor-de-videos.