Saltar al contenido

@capgo/capacitor-webview-crash

Recuperación de fallas de WebView nativo, reinicio manual y reciclaje programado de WebView para aplicaciones Capacitor de larga duración.

This plugin stores a native marker when the previous Capacitor WebView process dies or is recycled, then exposes that marker to the next JavaScript runtime after the app recovers. It can also restart the WebView from native code after a crash, on a fixed interval, on a cron schedule, or when JavaScript explicitly requests restartWebView()lo que ayuda a las aplicaciones de kiosk, POS, panel de control, escáner y de señalización a evitar la acumulación de memoria durante sesiones largas.

  • Reiniciar de crash nativo - Reinicia el WebView desde iOS o Android cuando el proceso de renderizado muere.
  • Reinicio programado - Recicla WebViews de larga duración en un temporizador nativo usando restartIntervalMs o un reloj de pared restartCron.
  • Reinicio manual nativo - Permite a JavaScript solicitar un WebView nativo fresco con restartWebView() sin realizar una recarga de página.
  • Configuración de tipo Capacitor - Exposición WebViewCrashPluginConfig para plugins.WebViewCrash en capacitor.config.ts.
  • getPendingCrashInfo - Devuelve el marcador de crash o reinicio nativo almacenado, o null - Elimina el marcador almacenado después de que tu aplicación haya restaurado su estado.
  • clearPendingCrashInfo - Crea un marcador de crash falso para que los flujos de recuperación puedan ser probados localmente.
  • simulateCrashRecovery - Dispara
  • addListener - para marcadores de crash y webViewRestoredAfterCrash - para cualquier marcador de reinicio nativo. webViewRestoredAfterRestart Public __CAPGO_KEEP_0__

Sección titulada “Public API”

Section titled “Public API”
DescripciónDevuelve el marcador de crash o reinicio nativo almacenado, o
getPendingCrashInfo- Fires for crash markers and for any native restart marker. null cuando no hay nada pendiente.
clearPendingCrashInfoElimina el marcador almacenado después de que tu aplicación haya restaurado su estado.
simulateCrashRecoveryCrea un marcador de falla ficticio para que los flujos de recuperación puedan ser probados localmente.
restartWebViewEscribe reason: 'manualRestart' y pregunta a code nativo para crear un WebView fresco.
addListenerDispara webViewRestoredAfterCrash o webViewRestoredAfterRestart cuando un oyente se adjunta y un marcador coincidente todavía está pendiente.
removeAllListenersElimina todos los oyentes de plugin.

El plugin agrega a Capacitor’s PluginsConfig con una configuración tipo: WebViewCrash entrada de configuración:

export interface WebViewCrashPluginConfig {
restartOnCrash?: boolean;
restartIntervalMs?: number;
restartCron?: string;
restartAfterCrashDelayMs?: number;
}
  • Este plugin detecta la recuperación después de un crash de WebView. No previene el crash subyacente.
  • El entorno de tiempo de ejecución JavaScript recuperado es nuevo, por lo que cualquier estado en memoria desde el WebView anterior ya ha desaparecido cuando se dispara este API.
  • Reinicios programados escriben reason: 'periodicRestart'; reinicios manuales escriben reason: 'manualRestart'. Guarda el estado no guardado antes de habilitar intervalos de reinicio cortos, horarios de cron o llamadas restartWebView().
  • restartCron usa la sintaxis de cron de 5 campos en la zona horaria local del dispositivo, por ejemplo 0 3 * * * para un reinicio diario a las 03:00. 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.
  • En Android, campos adicionales como didCrash y rendererPriorityAtExit pueden estar disponibles.
  • En iOS, el plugin registra appState cuando se observa el proceso de WebView terminado. Los reinicios manuales y programados reconstruyen la vista del puente Capacitor para crear un nuevo WKWebView .

Esta referencia se sincroniza desde src/definitions.ts en capacitor-webview-crash.

Sigue adelante desde @capgo/capacitor-webview-crash

Sección titulada “Sigue adelante desde @capgo/capacitor-webview-crash”

Si estás utilizando @capgo/capacitor-webview-crash para planificar el comportamiento de medios y interfaz nativa, 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-live-activities 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.