@capacitor/app
App API 负责处理应用的高级状态和事件。例如,当应用进入和离开前台时,该 API 会发出事件,处理深度链接,打开其他应用,并管理持久化的插件状态。
安装
npm install @capacitor/app@latest-7
npx cap sync
iOS
要能够通过自定义协议打开应用,您需要先注册该协议。您可以通过编辑 Info.plist 文件并添加以下行来实现。
<key>CFBundleURLTypes</key>
<array>
<dict>
<key>CFBundleURLName</key>
<string>com.getcapacitor.capacitor</string>
<key>CFBundleURLSchemes</key>
<array>
<string>mycustomscheme</string>
</array>
</dict>
</array>
Android
要能够通过自定义协议打开应用,您需要先注册该协议。您可以通过在 AndroidManifest.xml 的 activity 部分添加以下行来实现。
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="@string/custom_url_scheme" />
</intent-filter>
custom_url_scheme 的值存储在 strings.xml 中。当添加 Android 平台时,@capacitor/cli 会添加应用的包名作为默认值,但可以通过编辑 strings.xml 文件来替换。
示例
import { App } from '@capacitor/app';
App.addListener('appStateChange', ({ isActive }) => {
console.log('应用状态发生变化。是否处于活动状态?', isActive);
});
App.addListener('appUrlOpen', (data) => {
console.log('应用通过 URL 打开:', data);
});
App.addListener('appRestoredResult', (data) => {
console.log('恢复的状态:', data);
});
const checkAppLaunchUrl = async () => {
const { url } = await App.getLaunchUrl();
console.log('应用通过 URL 打开:' + url);
};
配置
| 属性 | 类型 | 描述 | 默认值 | 始于 |
|---|---|---|---|---|
disableBackButtonHandler | boolean | 禁用插件的默认返回按钮处理。仅适用于 Android。 | false | 7.1.0 |
示例
在 capacitor.config.json 中:
{
"plugins": {
"App": {
"disableBackButtonHandler": true
}
}
}
在 capacitor.config.ts 中:
/// <reference types="@capacitor/app" />
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
plugins: {
App: {
disableBackButtonHandler: true,
},
},
};
export default config;
API
exitApp()getInfo()getState()getLaunchUrl()minimizeApp()toggleBackButtonHandler(...)addListener('appStateChange', ...)addListener('pause', ...)addListener('resume', ...)addListener('appUrlOpen', ...)addListener('appRestoredResult', ...)addListener('backButton', ...)removeAllListeners()- 接口
- 类型别名
exitApp()
exitApp() => Promise<void>
强制退出应用。这应仅与 Android 的 backButton 处理程序结合使用,以便在导航完成时退出应用。
Ionic 自身会处理此操作,因此如果您使用 Ionic,则无需调用此方法。
始于: 1.0.0
getInfo()
getInfo() => Promise<AppInfo>
返回有关应用的信息。
返回值:
Promise<AppInfo>
始于: 1.0.0
getState()
getState() => Promise<AppState>
获取当前应用状态。
返回值:
Promise<AppState>
始于: 1.0.0
getLaunchUrl()
getLaunchUrl() => Promise<AppLaunchUrl | undefined>
获取应用启动时使用的 URL(如果有)。
返回值:
Promise<AppLaunchUrl>
始于: 1.0.0
minimizeApp()
minimizeApp() => Promise<void>