概述
概述标题该插件在前一个Capacitor WebView 进程死亡或回收时存储一个原生标记,然后在应用恢复后将该标记暴露给下一个 JavaScript 运行时。它还可以在崩溃后从原生code重启 WebView,或者在 JavaScript 明确请求时,或者在固定时间间隔,或者在 cron 计划中 restartWebView()这有助于避免长时间会话期间的内存积累,适用于 kiosk、POS、仪表板、扫描器和标牌应用
核心能力
核心能力- 原生崩溃重启 - 在 iOS 或 Android 中重启 WebView 当渲染进程死亡时。
- 定时重启 - 使用原生定时器在长时间运行的 WebView 上回收
restartIntervalMs或墙壁时钟restartCron. - 手动本地重启 - 让 JavaScript 请求一个新的本地 WebView
restartWebView()而不需要重新加载页面。 - 类型的 Capacitor 配置 - exposing
WebViewCrashPluginConfig用于plugins.WebViewCrash在capacitor.config.ts. getPendingCrashInfo- 返回存储的本地崩溃或重启标记,或者null当没有任何待处理的标记时。clearPendingCrashInfo- 清除存储的标记后,应用程序恢复其状态。simulateCrashRecovery- 创建一个虚拟崩溃标记,以便在本地测试恢复流程。addListener- 触发webViewRestoredAfterCrash用于崩溃标记和webViewRestoredAfterRestart对于任何本地重启标记。
公共API
标题为“公共API”的部分| 方法 | 描述 |
|---|---|
getPendingCrashInfo | 返回存储的本地崩溃或重启标记,或者 null 当没有待处理的标记时。 |
clearPendingCrashInfo | 在应用恢复其状态后清除存储的标记。 |
simulateCrashRecovery | 创建一个虚拟崩溃标记,以便在本地测试恢复流程。 |
restartWebView | 写入 reason: 'manualRestart' 并要求本地code创建一个新的 WebView。 |
addListener | 触发 webViewRestoredAfterCrash 或 webViewRestoredAfterRestart 当一个监听器附加并且一个匹配的标记仍然是待定的情况下。 |
removeAllListeners | 移除所有插件监听器。 |
配置类型
标题:配置类型该插件增强了Capacitor的 PluginsConfig 一个类型化的 WebViewCrash 配置项:
export interface WebViewCrashPluginConfig { restartOnCrash?: boolean; restartIntervalMs?: number; restartCron?: string; restartAfterCrashDelayMs?: number;}注意
标题:注意- 该插件检测了WebView崩溃后的恢复。它不会防止底层崩溃。
- 新 JavaScript 运行时是新的,所以在 WebView 之前的内存状态在这个 API 触发时已经消失了。
- 预定重启写入
reason: 'periodicRestart';手动重启写入reason: 'manualRestart'。在启用短重启间隔、cron 计划或调用前,保存未保存的状态。restartWebView(). restartCron使用设备本地时区的 5 个字段 cron 语法,例如0 3 * * *每天 03:00 重启。不要同时配置两个计划:native 初始化会在restartCron设置且restartIntervalMs大于时抛出致命配置错误。0.- 在 Android 上,额外的字段,如
didCrash和rendererPriorityAtExit可能可用。 - 在 iOS 上,插件会记录
appState当终止的 WebView 过程被观察到时。手动和计划重启重建了 Capacitor 桥接视图以便创建一个新的WKWebView是创建的。
真实来源
标题:真实来源此参考资料是从 src/definitions.ts 在 capacitor-webview-crash.
从 @capgo/capacitor-webview-crash 继续
标题:从 @capgo/capacitor-webview-crash 继续如果您正在使用 @capgo/capacitor-webview-crash 来规划原生媒体和界面行为,连接它 使用@capgo/capacitor-webview-crash 为native能力在使用@capgo/capacitor-webview-crash 使用@capgo/capacitor-live-activities 为native能力在使用@capgo/capacitor-live-activities @capgo/capacitor-live-activities 为@capgo/capacitor-live-activities的实现细节 使用@capgo/capacitor-video-player 为native能力在使用@capgo/capacitor-video-player @capgo/capacitor-video-player 为@capgo/capacitor-video-player的实现细节