开始入门
复制一个包含安装步骤和完整 Markdown 指南的配置提示。
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-webview-crash`
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/webview-crash/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.
安装
安装您可以使用我们的AI辅助设置来安装插件。使用以下命令将Capgo技能添加到您的AI工具中:
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-plugins然后使用以下提示:
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/capacitor-webview-crash` plugin in my project.如果您更喜欢手动设置,请运行以下命令并按照以下平台特定的说明进行安装:
npm install @capgo/capacitor-webview-crashnpx cap sync导入
导入import { WebViewCrash } from '@capgo/capacitor-webview-crash';推荐恢复流程
推荐恢复流程尽早在应用启动时附加监听器,以便恢复的运行时可以在用户继续浏览之前做出反应:
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);}原生自动重启
原生自动重启在 capacitor.config.ts 以便决策在JavaScript运行时崩溃或尚未加载时仍然在原生code中:
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;用于 restartIntervalMs 始终在线应用,用户可能在几天内保持相同的WebView打开:自助屏幕、控制室仪表盘、仓库扫描器、POS终端、车队平板电脑和数字显示屏。用于 restartCron 墙时钟重启,如 0 3 * * * 每天 03:00 重启设备本地时区。预定的重启写入一个等待标记与 reason: 'periodicRestart',然后Android重新创建宿主活动,iOS重建Capacitor桥视图,因此创建了一个新的 WKWebView 从本机code创建。
选择一个间隔或 cron 计划,您的产品可以容忍。 restartCron 支持 *,列表,范围和步骤。不要同时配置两个计划:本机初始化会抛出一个致命配置错误,当 restartCron 设置并且 restartIntervalMs 大于 0。重启创建了一个新的 JavaScript 运行时,因此在使用激进计划之前,请保存排队事件、未保存的表单状态和当前导航状态。
手动本机重启
标题:手动本机重启Call restartWebView() 当当前 JavaScript 运行时决定原生 WebView 应该被替换时,例如在内存密集型工作流程之后或进入长时间未attended 会话之前:
await WebViewCrash.restartWebView();该方法写入一个待处理的标记符号, reason: 'manualRestart'解决当前调用,然后要求原生 code 创建一个新的 WebView。Android 重建宿主活动。iOS 重建 Capacitor 桥视图以创建一个新的 WKWebView 而不是重新加载当前页面。
API 概述
标题:API 概述getPendingCrashInfo
标题:getPendingCrashInfo返回存储的原生崩溃或重启标记,或者 null 当没有待处理的标记时。
const pending = await WebViewCrash.getPendingCrashInfo();if (pending.value) { console.log(pending.value.platform, pending.value.reason);}clearPendingCrashInfo
标题:clearPendingCrashInfo在恢复处理完成后,清除存储的标记。
await WebViewCrash.clearPendingCrashInfo();simulateCrashRecovery
模拟崩溃恢复创建一个假的崩溃标记,以便 QA 和本地调试可以在不崩溃真实 WebView 的情况下演练恢复路径。
const simulated = await WebViewCrash.simulateCrashRecovery();console.log(simulated.value);restartWebView
重启 WebView存储一个手动重启标记,并要求本地 code 创建一个新的 WebView。
await WebViewCrash.restartWebView();平台说明
模拟崩溃恢复- Android 存储崩溃元数据
onRenderProcessGone包括didCrashandrendererPriorityAtExit当平台提供时, - iOS 从
webViewWebContentProcessDidTerminate和添加当前应用程序状态(可用时)。 - 手动和计划重启创建一个新的 WebView。 Android 重建宿主活动; iOS 重建Capacitor 桥视图。
- 计划重启使用
reason: 'periodicRestart';手动重启使用reason: 'manualRestart'. - Web 不检测真实渲染器崩溃。 Web 实现仅使用本地存储模拟此行为。
类型参考
标题:类型参考PendingCrashInfoResult
标题:PendingCrashInfoResultexport interface PendingCrashInfoResult { /** * Stored crash or restart metadata, or `null` when no marker is pending. */ value: WebViewCrashInfo | null;}WebViewCrashPluginConfig
WebViewCrashPluginConfigexport 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;}WebViewCrashInfo
WebViewCrashInfoexport 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;}WebViewCrashPlatform
WebViewCrashPlatformexport type WebViewCrashPlatform = 'android' | 'ios' | 'web';WebViewCrashReason
WebViewCrashReasonexport type WebViewCrashReason = | 'renderProcessGone' | 'webContentProcessDidTerminate' | 'periodicRestart' | 'manualRestart' | 'simulated';WebViewCrashAppState
WebViewCrashAppStateexport type WebViewCrashAppState = 'active' | 'inactive' | 'background' | 'unknown';真实数据来源
真实数据来源本页面由插件生成 src/definitions.ts当公共API上游发生变化时,请重新同步
从 Getting Started 继续
标题为“从 Getting Started 继续”如果您正在使用 Getting Started 来规划原生媒体和界面行为,连接它到 使用 @capgo/capacitor-webview-crash 为原生能力在使用 @capgo/capacitor-webview-crash 中 使用 @capgo/capacitor-live-activities 为原生能力在使用 @capgo/capacitor-live-activities 中 @capgo/capacitor-live-activities 对于 @capgo/capacitor-live-activities 的实现细节 使用 @capgo/capacitor-video-player 使用 @capgo/capacitor-video-player 的原生功能 @capgo/capacitor-video-player 对于 @capgo/capacitor-video-player 的实现细节