@capacitor/app
App API 负责处理应用的高级状态和事件。例如,当应用进入或离开前台时,该 API 会发出事件,同时负责处理深度链接、打开其他应用以及管理持久化的插件状态。
安装
npm install @capacitor/app
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);
};