StatusBar
用于控制应用状态栏的组件。状态栏通常是屏幕顶部的区域,显示当前时间、Wi-Fi 和蜂窝网络信息、电池电量和/或其他状态图标。
与 Navigator 一起使用
可以同时挂载多个 StatusBar 组件。props 将按照 StatusBar 组件挂载的顺序进行合并。
- TypeScript
- JavaScript
命令式 API
对于使用组件并不理想的情况,还有一个作为组件上的静态函数暴露的命令式 API。然而,不建议对同一个 prop 同时使用静态 API 和组件,因为静态 API 设置的任何值将在下一次渲染中被组件设置的值覆盖。
参考
常量
currentHeight Android
状态栏的高度,包括缺口(notch)高度(如果存在)。
属性
animated
状态栏属性更改之间的过渡是否应该动画化。支持 backgroundColor、barStyle 和 hidden 属性。
| 类型 | 必填 | 默认值 |
|---|---|---|
| boolean | 否 | false |
backgroundColor Android
状态栏的背景颜色。
由于 Android 15 引入的边到边(edge-to-edge)强制要求,在 API 级别 35 中设置状态栏背景颜色已弃用,设置它将无效。您可以在 这里 阅读更多关于我们的边到边建议。
| 类型 | 必填 | 默认值 |
|---|---|---|
| color | 否 | 默认系统 StatusBar 背景颜色,如果未定义则为 'black' |
barStyle
设置状态栏文本的颜色。
在 Android 上,这只会影响 API 版本 23 及以上版本。
| 类型 | 必填 | 默认值 |
|---|---|---|
| StatusBarStyle | 否 | 'default' |
hidden
是否隐藏状态栏。
| 类型 | 必填 | 默认值 |
|---|---|---|
| boolean | 否 | false |
networkActivityIndicatorVisible iOS
网络活动指示器是否应该可见。
| 类型 | 默认值 |
|---|---|
| boolean | false |
showHideTransition iOS
使用 hidden 属性显示和隐藏状态栏时的过渡效果。
| 类型 | 默认值 |
|---|---|
| StatusBarAnimation | 'fade' |
translucent Android
状态栏是否为半透明。当 translucent 设置为 true 时,应用将在状态栏下方绘制。这对于使用半透明状态栏颜色时很有用。
由于 Android 15 引入的边到边(edge-to-edge)强制要求,在 API 级别 35 中设置状态栏为半透明已弃用,设置它将无效。您可以在 这里 阅读更多关于我们的边到边建议。
| 类型 | 默认值 |
|---|---|
| boolean | false |
方法
popStackEntry()
static popStackEntry(entry: StatusBarProps);
获取并从栈中移除最后一个 StatusBar 条目。
参数:
| 名称 | 类型 | 描述 |
|---|---|---|
| entry 必填 | 任何 | 从 pushStackEntry 返回的条目。 |
pushStackEntry()
static pushStackEntry(props: StatusBarProps): StatusBarProps;
将 StatusBar 条目推送到栈上。完成后,返回值应传递给 popStackEntry。
参数:
| 名称 | 类型 | 描述 |
|---|---|---|
| props 必填 | 任何 | 包含要在栈条目中使用的 StatusBar props 的对象。 |
replaceStackEntry()
static replaceStackEntry(
entry: StatusBarProps,
props: StatusBarProps
): StatusBarProps;
用新的 props 替换现有的 StatusBar 栈条目。
参数:
| 名称 | 类型 | 描述 |
|---|---|---|
| entry 必填 | 任何 | 从 pushStackEntry 返回的要替换的条目。 |
| props 必填 | 任何 | 包含要在替换栈条目中使用的 StatusBar props 的对象。 |
setBackgroundColor() Android
static setBackgroundColor(color: ColorValue, animated?: boolean);
设置状态栏的背景颜色。
由于 Android 15 引入的边到边(edge-to-edge)强制要求,在 API 级别 35 中设置状态栏背景颜色已弃用,设置它将无效。您可以在 这里 阅读更多关于我们的边到边建议。
参数:
| 名称 | 类型 | 描述 |
|---|---|---|
| color 必填 | string | 背景颜色。 |
| animated | boolean | 动画化样式更改。 |
setBarStyle()
static setBarStyle(style: StatusBarStyle, animated?: boolean);
设置状态栏样式。
参数:
| 名称 | 类型 | 描述 |
|---|---|---|
| style 必填 | StatusBarStyle | 要设置的状态栏样式。 |
| animated | boolean | 动画化样式更改。 |
setHidden()
static setHidden(hidden: boolean, animation?: StatusBarAnimation);
显示或隐藏状态栏。
参数:
| 名称 | 类型 | 描述 |
|---|---|---|
| hidden 必填 | boolean | 隐藏状态栏。 |
| animation iOS | StatusBarAnimation | 更改状态栏 hidden 属性时的动画。 |
🗑️ setNetworkActivityIndicatorVisible() iOS
状态栏网络活动指示器在 iOS 13 及更高版本中不受支持。这将在未来的版本中移除。
static setNetworkActivityIndicatorVisible(visible: boolean);
控制网络活动指示器的可见性。
参数:
| 名称 | 类型 | 描述 |
|---|---|---|
| visible 必填 | boolean | 显示指示器。 |
setTranslucent() Android
static setTranslucent(translucent: boolean);
控制状态栏的半透明度。
由于 Android 15 引入的边到边(edge-to-edge)强制要求,在 API 级别 35 中设置状态栏为半透明已弃用,设置它将无效。您可以在 这里 阅读更多关于我们的边到边建议。
参数:
| 名称 | 类型 | 描述 |
|---|---|---|
| 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) |