跳到主要内容
版本:v8

@capacitor/status-bar

StatusBar API 提供了配置状态栏样式以及显示或隐藏状态栏的方法。

安装

npm install @capacitor/status-bar
npx cap sync

Android 16+ 行为变更

针对使用 Capacitor 8 且目标版本为 Android 16(API 等级 36) 或更高的应用,以下状态栏配置选项将不再生效

  • overlaysWebView
  • backgroundColor

这些选项依赖于能够选择退出安卓的边到边(edge-to-edge) 系统 UI 行为,该行为允许应用控制状态栏的覆盖方式及其背景颜色。

Android 15(API 等级 35) 中,仍然可以通过在应用布局文件中设置 windowOptOutEdgeToEdgeEnforcement 属性来退出这种强制行为。 如果没有该属性,应用会将 overlaysWebView 视为始终 true。 更多详情请参阅安卓文档:https://developer.android.com/reference/android/R.attr#windowOptOutEdgeToEdgeEnforcement

Android 16 开始,此退出选项不再可用,该行为由系统强制执行。
因此,overlaysWebViewbackgroundColor 配置选项将不再产生任何效果。

iOS 说明

此插件要求在 Info.plist 中将 "View controller-based status bar appearance"(UIViewControllerBasedStatusBarAppearance)设置为 YES。请阅读 配置 iOS 获取帮助。

状态栏默认可见,样式默认为 Style.Default。您可以通过在 Info.plist 中添加 UIStatusBarHidden 和/或 UIStatusBarStyle 来更改这些默认值。

示例

import { StatusBar, Style } from '@capacitor/status-bar';

// 仅限 iOS
window.addEventListener('statusTap', function () {
console.log('状态栏被点击');
});

// 在透明状态栏下显示内容
StatusBar.setOverlaysWebView({ overlay: true });

const setStatusBarStyleDark = async () => {
await StatusBar.setStyle({ style: Style.Dark });
};

const setStatusBarStyleLight = async () => {
await StatusBar.setStyle({ style: Style.Light });
};

const hideStatusBar = async () => {
await StatusBar.hide();
};

const showStatusBar = async () => {
await StatusBar.show();
};

配置

可用的配置值如下:

属性类型描述默认值始于版本
overlaysWebViewboolean状态栏是否覆盖在 WebView 之上。在 Android 15+ 上不可用。true1.0.0
stylestring状态栏文本的样式default1.0.0
backgroundColorstring状态栏背景颜色的十六进制格式,例如 #RRGGBB。如果 overlaysWebView 为 true 则不生效。在 Android 15+ 上不可用。#0000001.0.0

示例

capacitor.config.json 中:

{
"plugins": {
"StatusBar": {
"overlaysWebView": false,
"style": "DARK",
"backgroundColor": "#ffffffff"
}
}
}

capacitor.config.ts 中:

/// <reference types="@capacitor/status-bar" />

import { CapacitorConfig } from '@capacitor/cli';

const config: CapacitorConfig = {
plugins: {
StatusBar: {
overlaysWebView: false,
style: "DARK",
backgroundColor: "#ffffffff",
},
},
};

export default config;

API

setStyle(...)

setStyle(options: StyleOptions) => Promise<void>

设置状态栏的当前样式。

参数类型
options
StyleOptions

始于版本: 1.0.0


setBackgroundColor(...)

setBackgroundColor(options: BackgroundColorOptions) => Promise<void>

设置状态栏的背景颜色。 如果样式设置为默认,调用此函数将更新状态栏的前景颜色(iOS 17 以下版本除外)。 在 Android 15+ 上不可用。

参数类型
options
BackgroundColorOptions

始于版本: 1.0.0


show(...)

show(options?: AnimationOptions | undefined) => Promise<void>

显示状态栏。 在 iOS 上,如果状态栏最初被隐藏且初始样式设置为 UIStatusBarStyleLightContent,则首次调用 show 时,动画可能会显示文本为深色然后过渡到浅色的闪烁现象。建议在首次调用时使用 Animation.None 作为动画选项。

参数类型
options
AnimationOptions

始于版本: 1.0.0


hide(...)

hide(options?: AnimationOptions | undefined) => Promise<void>

隐藏状态栏。

参数类型
options
AnimationOptions

始于版本: 1.0.0


getInfo()

getInfo() => Promise<StatusBarInfo>

获取状态栏当前状态的信息。

返回:

Promise<StatusBarInfo>

自版本: 1.0.0


setOverlaysWebView(...)

setOverlaysWebView(options: SetOverlaysWebViewOptions) => Promise<void>

设置状态栏是否应覆盖 WebView,以便使用其下方的空间。 不适用于 Android 15+。

参数类型
options
SetOverlaysWebViewOptions

自版本: 1.0.0


addListener('statusBarVisibilityChanged', ...)

addListener(eventName: 'statusBarVisibilityChanged', listenerFunc: VisibilityChangeListener) => Promise<PluginListenerHandle>

监听状态栏可见性变化。 当 hide 或 show 方法被调用时触发。

参数类型
eventName'statusBarVisibilityChanged'
listenerFunc
VisibilityChangeListener

返回:

Promise<PluginListenerHandle>

自版本: 7.0.0


addListener('statusBarOverlayChanged', ...)

addListener(eventName: 'statusBarOverlayChanged', listenerFunc: OverlayChangeListener) => Promise<PluginListenerHandle>

监听状态栏覆盖状态变化。 当 setOverlaysWebView 被调用时触发。

参数类型
eventName'statusBarOverlayChanged'
listenerFunc
OverlayChangeListener

返回:

Promise<PluginListenerHandle>

自版本: 7.0.0


接口

StyleOptions

属性类型描述自版本
style
Style
状态栏文本的样式1.0.0

BackgroundColorOptions

属性类型描述自版本
colorstring用于设置状态栏颜色的十六进制颜色值。1.0.0

AnimationOptions

属性类型描述默认值自版本
animation
Animation
显示或隐藏状态栏时使用的动画类型。此选项仅在 iOS 上受支持。Animation.Fade1.0.0

StatusBarInfo

属性类型描述自版本
visibleboolean状态栏是否可见。1.0.0
style
Style
当前状态栏样式。1.0.0
colorstring当前状态栏颜色。1.0.0
overlaysboolean状态栏是否处于覆盖模式。1.0.0
heightnumber状态栏的高度。7.0.0

SetOverlaysWebViewOptions

属性类型描述自版本
overlayboolean是否将状态栏设置为覆盖模式。1.0.0

PluginListenerHandle

属性类型
remove() => Promise<void>

类型别名

VisibilityChangeListener

(info: StatusBarInfo): void

OverlayChangeListener

(info: StatusBarInfo): void

枚举

Style

成员描述自版本
Dark'DARK'深色背景上的浅色文本。1.0.0
Light'LIGHT'浅色背景上的深色文本。1.0.0
Default'DEFAULT'样式基于设备外观。如果设备使用深色模式,状态栏文本将为浅色;如果设备使用浅色模式,状态栏文本将为深色。1.0.0

Animation

成员描述自版本
None'NONE'显示/隐藏时无动画。1.0.0
Slide'SLIDE'显示/隐藏时使用滑动动画。在 iOS 15+ 上无效。1.0.0
Fade'FADE'显示/隐藏时使用淡入淡出动画。1.0.0