@capacitor/inappbrowser
InAppBrowser 插件提供了一个网页浏览器视图,允许您在外部加载任意网页。其行为与标准网页浏览器一致,可用于加载不受信任的内容而不会威胁应用程序的安全性。它提供三种不同的 URL 打开方式:在 WebView 中、在应用内系统浏览器(Android 上的 Custom Tabs 和 iOS 上的 SFSafariViewController)中,以及在设备的默认浏览器中。
安装
npm install @capacitor/inappbrowser
npx cap sync
支持的平台
- iOS
- Android
Android
InAppBrowser 插件要求 Android SDK 的最低目标版本为 26,这高于 Capacitor 应用程序的默认值。您可以在 android/variables.gradle
文件中更新此值。
ext {
minSdkVersion = 26
}
使用示例
在外部浏览器中打开
import { InAppBrowser } from '@capacitor/inappbrowser';
await InAppBrowser.openInExternalBrowser({
url: 'https://www.google.com',
});
在系统浏览器中打开(Android 使用 Custom Tabs,iOS 使用 SFSafariViewController)
import { InAppBrowser, DefaultSystemBrowserOptions } from '@capacitor/inappbrowser';
await InAppBrowser.openInSystemBrowser({
url: 'https://www.google.com',
options: DefaultSystemBrowserOptions,
});
在 Web View 中打开
import { InAppBrowser, DefaultWebViewOptions } from '@capacitor/inappbrowser';
await InAppBrowser.openInWebView({
url: 'https://www.google.com',
options: DefaultWebViewOptions,
});
关闭(Web View 或系统浏览器)
import { InAppBrowser } from '@capacitor/inappbrowser';
await InAppBrowser.close();
添加监听器
import { InAppBrowser } from '@capacitor/inappbrowser';
await InAppBrowser.addListener('browserClosed', () => {
console.log('浏览器已关闭。');
});
await InAppBrowser.addListener('browserPageNavigationCompleted', (data) => {
console.log('浏览器页面导航完成。URL: ' + data.url);
});
await InAppBrowser.addListener('browserPageLoaded', () => {
console.log('浏览器已加载。');
});
移除所有监听器
import { InAppBrowser } from '@capacitor/inappbrowser';
InAppBrowser.removeAllListeners();
API
openInWebView(...)
openInWebView(model: OpenInWebViewParameterModel) => Promise<void>
在您的移动应用中使用自定义的 Web View 打开指定 URL 的网页内容。
参数 | 类型 | 描述 |
---|---|---|
model |
| 用于在 Web View 中打开 URL 的参数 |
openInSystemBrowser(...)
openInSystemBrowser(model: OpenInSystemBrowserParameterModel) => Promise<void>
在您的移动应用中使用系统浏览器打开指定 URL 的网页内容,iOS 使用 SafariViewController,Android 使用 Custom Tabs。
参数 | 类型 | 描述 |
---|---|---|
model |
| 用于在系统浏览器中打开 URL 的参数 |
openInExternalBrowser(...)
openInExternalBrowser(model: OpenInDefaultParameterModel) => Promise<void>
在移动应用之外的独立浏览器中打开指定 URL 的网页内容。
参数 | 类型 | 描述 |
---|---|---|
model |
| 用于在外部浏览器中打开 URL 的参数 |
close()
close() => Promise<void>
关闭当前活动的浏览器。可用于关闭通过 openInSystemBrowser 或 openInWebView 操作启动的浏览器。
addListener('browserClosed' | 'browserPageLoaded', ...)
addListener(eventName: 'browserClosed' | 'browserPageLoaded', listenerFunc: () => void) => Promise<PluginListenerHandle>
为指定的浏览器事件添加监听器,不返回数据。
参数 | 类型 | 描述 |
---|---|---|
eventName | 'browserClosed' | 'browserPageLoaded' | 要监听的浏览器事件名称:'browserClosed' 或 'browserPageLoaded'。 |
listenerFunc | () => void | 事件发生时调用的函数。 |
返回值:
Promise<PluginListenerHandle>
addListener('browserPageNavigationCompleted', ...)
addListener(eventName: 'browserPageNavigationCompleted', listenerFunc: (data: BrowserPageNavigationCompletedEventData) => void) => Promise<PluginListenerHandle>
为指定的浏览器事件添加监听器,该事件会接收数据。
参数 | 类型 | 描述 |
---|---|---|
eventName | 'browserPageNavigationCompleted' | 要监听的浏览器事件名称:'browserPageNavigationCompleted'。仅适用于 openInWebView。 |
listenerFunc |
| 事件发生时调用的函数。 |
返回值:
Promise<PluginListenerHandle>
removeAllListeners()
removeAllListeners() => void
移除所有浏览器事件的监听器。
Interfaces
OpenInWebViewParameterModel
定义在 Web View 中打开 URL 的选项。
属性 | 类型 | 描述 |
---|---|---|
options |
| 包含要应用于 Web View 的一些配置的结构体。 |
customHeaders | { [key: string]: string; } | 随请求发送的自定义头部映射。 |
WebViewOptions
属性 | 类型 | 描述 |
---|---|---|
showURL | boolean | 在 Web View 上显示 URL。 |
showToolbar | boolean | 在 Web View 上显示工具栏。 |
clearCache | boolean | 在新窗口打开前清除 Web View 的 cookie 缓存。 |
clearSessionCache | boolean | 在新窗口打开前清除会话 cookie 缓存。 |
mediaPlaybackRequiresUserAction | boolean | 防止 HTML5 音频或视频自动播放。 |
closeButtonText | string | 设置 Web View 上关闭按钮显示的文本。 |
toolbarPosition |
| 设置 Web View 上工具栏的显示位置。 |
showNavigationButtons | boolean | 显示导航按钮。 |
leftToRight | boolean | 交换导航按钮和关闭按钮的位置。 |
customWebViewUserAgent | string | null | 设置打开 Web View 时使用的自定义用户代理。如果为空或未设置,则忽略 此参数。 |
android |
| Android 特定的 Web View 选项。 |
iOS |
| iOS 特定的 Web View 选项。 |
AndroidWebViewOptions
属性 | 类型 | 描述 |
---|---|---|
allowZoom | boolean | 显示 Android 浏览器的缩放控件。 |
hardwareBack | boolean | 使用硬件返回按钮在 Web View 的历史记录中向后导航。如果没有上一页,Web View 将关闭。 |
pauseMedia | boolean | 使 Web View 随应用暂停/恢复以停止后台音频。 |
iOSWebViewOptions
属性 | 类型 | 描述 |
---|---|---|
allowOverScroll | boolean | 开启 Web View 的弹性属性。 |
enableViewportScale | boolean | 通过 meta 标签阻止视口缩放。 |
allowInLineMediaPlayback | boolean | 允许内联 HTML5 媒体播放,在浏览器窗口内显示,而不是设备特定的播放界面。注意:HTML 的 video 元素也必须包含 webkit-playsinline 属性。 |
surpressIncrementalRendering | boolean | 等待接收到所有新视图内容后再进行渲染。 |
viewStyle |
| 设置 Web View 的呈现样式。 |
animationEffect |
| 设置 Web View 的过渡样式。 |
allowsBackForwardNavigationGestures | boolean | 在 Web View 中启用前后滑动手势。 |
OpenInSystemBrowserParameterModel
定义在系统浏览器中打开 URL 的选项。
属性 | 类型 | 描述 |
---|---|---|
options |
| 包含要应用于系统浏览器的一些配置的结构体。 |
SystemBrowserOptions
属性 | 类型 | 描述 |
---|---|---|
android |
| Android 特定的系统浏览器选项。 |
iOS |
| iOS 特定的系统浏览器选项。 |
AndroidSystemBrowserOptions
属性 | 类型 | 描述 |
---|---|---|
showTitle | boolean | 启用标题显示。 |
hideToolbarOnScroll | boolean | 滚动时隐藏工具栏。 |
viewStyle |
| 设置 CustomTabs 的呈现样式。 |
bottomSheetOptions |
| 当选择此视图样式为底部表单时设置其选项。如果视图样式为 FULL_SCREEN,则忽略此选项。 |
startAnimation |
| 设置浏览器出现时的起始动画。 |
exitAnimation |
| 设置浏览器消失时的退出动画。 |
AndroidBottomSheet
属性 | 类型 | 描述 |
---|---|---|
height | number | 设置底部表单的高度(以像素为单位)。Custom tabs 会将底部高度设置为屏幕的至少 50%。如果未传递值,则默认为最小值。 |
isFixed | boolean | 设置底部表单是否为固定模式。 |
iOSSystemBrowserOptions
属性 | 类型 | 描述 |
---|---|---|
closeButtonText |
| 设置用作关闭按钮标题的文本。 |
viewStyle |
| 设置 SafariViewController 的呈现样式。 |
animationEffect |
| 设置 SafariViewController 的过渡样式。 |
enableBarsCollapsing | boolean | 启用向下滚动时栏的折叠。 |
enableReadersMode | boolean | 启用阅读器模式。 |
OpenInDefaultParameterModel
定义在外部浏览器中打开 URL 的选项,并被其他方法使用。
属性 | 类型 | 描述 |
---|---|---|
url | string | 要打开的 URL。必须包含 'http' 或 'https' 作为协议前缀。 |
PluginListenerHandle
属性 | 类型 |
---|---|
remove | () => Promise<void> |
BrowserPageNavigationCompletedEventData
定义 'browserPageNavigationCompleted' 事件的数据。
属性 | 类型 | 描述 |
---|---|---|
url | string | 已加载页面的 URL。 |
Enums
ToolbarPosition
成员 |
---|
TOP |
BOTTOM |
iOSViewStyle
成员 |
---|
PAGE_SHEET |
FORM_SHEET |
FULL_SCREEN |
iOSAnimation
成员 |
---|
FLIP_HORIZONTAL |
CROSS_DISSOLVE |
COVER_VERTICAL |
AndroidViewStyle
成员 |
---|
BOTTOM_SHEET |
FULL_SCREEN |
AndroidAnimation
成员 |
---|
FADE_IN |
FADE_OUT |
SLIDE_IN_LEFT |
SLIDE_OUT_RIGHT |
DismissStyle
成员 |
---|
CLOSE |
CANCEL |
DONE |