跳到主要内容

StatusBar

用于控制应用状态栏的组件。状态栏是屏幕顶部通常显示当前时间、Wi-Fi 和蜂窝网络信息、电池电量和/或其他状态图标的区域。

与 Navigator 一起使用

可以同时挂载多个 StatusBar 组件。props 将按照 StatusBar 组件挂载的顺序合并。

命令式 API

对于组件不是理想选择的情况,还有一个命令式 API 作为组件上的静态函数公开。但是,不建议对同一 prop 同时使用静态 API 和组件,因为静态 API 设置的任何值都将在下一次渲染中被组件设置的值覆盖。


参考

常量

currentHeight
Android

状态栏的高度,包括刘海屏的高度(如果存在)。


Props

animated

状态栏属性更改之间的过渡是否应具有动画效果。支持 backgroundColorbarStylehidden 属性。

类型必需默认值
booleanfalse

backgroundColor
Android

状态栏的背景颜色。

warning

由于 Android 15 中引入了边缘到边缘的强制执行,因此在 API 级别 35 中,设置状态栏的背景颜色已被弃用。

类型必需默认值
color默认系统 StatusBar 背景颜色,如果未定义则为 'black'

barStyle

设置状态栏文本的颜色。

在 Android 上,这仅对 API 版本 23 及以上版本有效。

类型必需默认值
StatusBarStyle'default'

hidden

状态栏是否隐藏。

类型必需默认值
booleanfalse

networkActivityIndicatorVisible
iOS

网络活动指示器是否应可见。

类型默认值
booleanfalse

showHideTransition
iOS

使用 hidden prop 显示和隐藏状态栏时的过渡效果。

类型默认值
StatusBarAnimation'fade'

translucent
Android

状态栏是否半透明。当 translucent 设置为 true 时,应用将绘制在状态栏下方。当使用半透明状态栏颜色时,这很有用。

类型默认值
booleanfalse

方法

popStackEntry()

tsx
static popStackEntry(entry: StatusBarProps);

从堆栈中获取并移除最后一个 StatusBar 条目。

参数

名称类型描述
entry
必需
anypushStackEntry 返回的条目。

pushStackEntry()

tsx
static pushStackEntry(props: StatusBarProps): StatusBarProps;

将 StatusBar 条目推入堆栈。完成时,返回值应传递给 popStackEntry

参数

名称类型描述
props
必需
any包含要在堆栈条目中使用的 StatusBar props 的对象。

replaceStackEntry()

tsx
static replaceStackEntry(
entry: StatusBarProps,
props: StatusBarProps
): StatusBarProps;

用新的 props 替换现有的 StatusBar 堆栈条目。

参数

名称类型描述
entry
必需
any要替换的从 pushStackEntry 返回的条目。
props
必需
any包含要在替换堆栈条目中使用的 StatusBar props 的对象。

setBackgroundColor()
Android

tsx
static setBackgroundColor(color: ColorValue, animated?: boolean);

设置状态栏的背景颜色。

warning

由于 Android 15 中引入了边缘到边缘的强制执行,因此在 API 级别 35 中,设置状态栏的背景颜色已被弃用。

参数

名称类型描述
color
必需
string背景颜色。
animatedboolean动画显示样式更改。

setBarStyle()

tsx
static setBarStyle(style: StatusBarStyle, animated?: boolean);

设置状态栏样式。

参数

名称类型描述
style
必需
StatusBarStyle要设置的状态栏样式。
animatedboolean动画显示样式更改。

setHidden()

tsx
static setHidden(hidden: boolean, animation?: StatusBarAnimation);

显示或隐藏状态栏。

参数

名称类型描述
hidden
必需
boolean隐藏状态栏。
animation
iOS
StatusBarAnimation更改状态栏隐藏属性时的动画。

setNetworkActivityIndicatorVisible()
iOS

tsx
static setNetworkActivityIndicatorVisible(visible: boolean);

控制网络活动指示器的可见性。

参数

名称类型描述
visible
必需
boolean显示指示器。

setTranslucent()
Android

tsx
static setTranslucent(translucent: boolean);

控制状态栏的半透明度。

参数

名称类型描述
translucent
必需
boolean设置为半透明。

类型定义

StatusBarAnimation

iOS 上过渡的状态栏动画类型。

类型
enum

常量

类型描述
'fade'string淡入动画
'slide'string滑动动画
'none'string无动画

StatusBarStyle

状态栏样式类型。

类型
enum

常量

类型描述
'default'string默认状态栏样式(iOS 为深色,Android 为浅色)
'light-content'string白色文本和图标
'dark-content'string深色文本和图标(Android 上需要 API>=23)