Reference version

This is documentation for the next SDK version. For up-to-date documentation, see the latest version (SDK 55).

Expo NavigationBar

一个库,提供对 Android 原生导航栏各种交互的访问。

Android
Included in Expo Go

For the complete documentation index, see llms.txt. Use this Use this file to discover all available pages.

expo-navigation-bar 提供了一个组件和一个命令式 API,用于控制 Android 设备上的应用导航栏,允许你更改其按钮的颜色或将其隐藏。

安装

Terminal
npx expo install expo-navigation-bar

If you are installing this in an existing React Native app, make sure to install expo in your project.

在 app 配置中进行配置

如果你在项目中使用 config plugins(Continuous Native Generation (CNG)),你可以使用 expo-navigation-bar 内置的 config plugin 进行配置。该插件允许你配置各种无法在运行时设置、且需要构建新的应用二进制文件后才会生效的属性。如果你的应用使用 CNG,那么你需要手动配置该库。

Example app.json with config plugin

app.json
{ "expo": { "plugins": [ [ "expo-navigation-bar", { "enforceContrast": true, "hidden": false, "style": "light" } ] ] } }

Configurable properties

NameDefaultDescription
enforceContrasttrue
Only for:
Android

决定操作系统是否应保持导航栏半透明,以便在导航按钮与应用内容之间提供对比度。在 Android 9 及以下版本上无效。

hiddenundefined
Only for:
Android

决定状态栏是否初始为隐藏状态。接受 truefalse 作为值。

styleundefined
Only for:
Android

决定导航栏初始使用的样式。接受 lightdark 作为值。

Are you using this library in an existing React Native app?

如果你没有使用 Continuous Native Generation(CNG),或者你正在手动使用原生 android 项目,那么你需要在原生项目中添加以下配置:

  • 要在 Android 上隐藏导航栏,请将 expoNavigationBarHidden 添加到 android/app/src/main/res/values/styles.xml

    <style name="AppTheme" parent="Theme.AppCompat.DayNight.NoActionBar"> <!-- ... --> <item name="expoNavigationBarHidden">true</item> </style>

用法

Example
import { StyleSheet, Text, View } from 'react-native'; import { NavigationBar } from 'expo-navigation-bar'; export default function App() { return ( <View style={styles.container}> <Text style={styles.text}>注意,导航栏按钮现在是浅色的!</Text> <NavigationBar style="light" /> </View> ); } const styles = StyleSheet.create({ container: { flex: 1, backgroundColor: '#000', alignItems: 'center', justifyContent: 'center', }, text: { color: '#fff', }, });

API

import { NavigationBar } from 'expo-navigation-bar';

Component

Android

Type: React.Element<NavigationBarProps>

A component that allows you to configure your navigation bar declaratively.

You will likely have multiple NavigationBar components mounted in the same app at the same time. For example, if you have multiple screens in your app, you may end up using one per screen. The props of each NavigationBar component will be merged in the order that they were mounted.

NavigationBarProps

hidden

Android
Optional • Type: boolean

If the navigation bar is hidden.

style

Android
Optional • Type: NavigationBarStyle • Default: 'auto'

Sets the color of the navigation bar buttons. Default value is "auto" which picks the appropriate value according to the active color scheme, eg: if your app is dark mode, the style will be "light".

This will have an effect when the following conditions are met:

  • The device navigation bar is using buttons.
  • The enforceContrast option of the expo-navigation-bar plugin is set to false.

Due to a bug in the Android 15 emulator this function may have no effect. Try a physical device or an emulator with a different version of Android.

Component Methods

setHidden(hidden)

Android
ParameterTypeDescription
hiddenboolean

If the navigation bar should be hidden.


Set the navigation bar's visibility.

Returns:
void

Example

NavigationBar.setHidden(true);

setStyle(style)

Android
ParameterTypeDescription
styleNavigationBarStyle

The color of the navigation bar buttons.


Sets the style of the navigation bar.

This will have an effect when the following conditions are met:

  • The device navigation bar is using buttons.
  • The enforceContrast option of the expo-navigation-bar plugin is set to false.

Due to a bug in the Android 15 emulator this function may have no effect. Try a physical device or an emulator with a different version of Android.

Returns:
void

Example

NavigationBar.setStyle("dark");

Hooks

Deprecated: This will be removed in a future release.

useVisibility()

Android

React hook that statefully updates with the visibility of the system navigation bar.

Visibility of the navigation bar, null during async initialization.

Methods

Deprecated: This will be removed in a future release.

Android

Get the navigation bar's visibility.

Navigation bar's current visibility status. Returns hidden on unsupported platforms (iOS, web).

Deprecated: Use NavigationBar.setStyle instead. This will be removed in a future release.

Android
ParameterTypeDescription
styleNavigationBarStyle

The color of the navigation bar buttons.


Returns:
void

Deprecated: Use NavigationBar.setHidden instead. This will be removed in a future release.

Android
ParameterTypeDescription
visibilityNavigationBarVisibility

Based on CSS visibility property.


Set the navigation bar's visibility.

Returns:
Promise<void>

Event Subscriptions

Deprecated: This will be removed in a future release.

Android
ParameterType
listener(event: NavigationBarVisibilityEvent) => void

Observe changes to the system navigation bar. Due to platform constraints, this callback will also be triggered when the status bar visibility changes.

Returns:
EventSubscription

Types

Android

Literal Type: string

Navigation bar style.

  • auto will automatically adjust based on the current theme.
  • light a light navigation bar with dark content.
  • dark a dark navigation bar with light content.
  • inverted the bar colors are inverted in relation to the current theme.

Acceptable values are: 'auto' | 'inverted' | 'light' | 'dark'

Deprecated: This will be removed in a future release.

Android

Literal Type: string

Visibility of the navigation bar.

Acceptable values are: 'visible' | 'hidden'

Deprecated: This will be removed in a future release.

Android

Current system UI visibility state. Due to platform constraints, this will return when the status bar visibility changes as well as the navigation bar.

PropertyTypeDescription
rawVisibilitynumber

Native Android system UI visibility state, returned from the native Android setOnSystemUiVisibilityChangeListener API.

visibilityNavigationBarVisibility

Current navigation bar visibility.