Reference version

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

RNHostView

在 @expo/ui 视图中承载 React Native 视图的跨平台组件。

Android
iOS
Web
Included in Expo Go

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

在通用的 @expo/ui 布局中托管一个 React Native 视图子树。在 Android 和 iOS 上,它会重新导出平台原生的 RNHostView for Jetpack Compose/RNHostView for SwiftUI,因此 React Native 子节点会桥接到外层的 Compose/SwiftUI 树中。在 web 上,没有可桥接的原生宿主树,因此它会退回为一个包裹子节点的 React Native View

安装

Terminal
npx expo install @expo/ui

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

用法

基本用法

将一个 React Native 视图子树放在通用的 @expo/ui 布局中的任意位置。

RNHostViewExample.tsx
import { Host, Column, RNHostView, Text } from '@expo/ui'; import { Text as RNText, View } from 'react-native'; export default function RNHostViewExample() { return ( <Host matchContents> <Column spacing={12} style={{ padding: 16 }}> <Text textStyle={{ fontWeight: 'bold' }}>原生 UI 标签</Text> <RNHostView matchContents> <View style={{ alignSelf: 'flex-start', padding: 16, backgroundColor: '#9B59B6', borderRadius: 10, }}> <RNText style={{ color: 'white' }}>普通的 React Native 内容</RNText> </View> </RNHostView> </Column> </Host> ); }

填充父级 vs. 匹配子级

默认情况下,RNHostView 会填充其原生父级。将 matchContents 设为启用后,它会缩小以适应其 React Native 子节点。

RNHostViewExample.tsx
import { Host, Column, Row, Text, RNHostView } from '@expo/ui'; import { View } from 'react-native'; export default function RNHostViewExample() { return ( <Host matchContents> <Column spacing={24} style={{ padding: 16 }}> <Column spacing={8}> <Text textStyle={{ fontSize: 18, fontWeight: 'bold' }}>填充父级尺寸</Text> <Text textStyle={{ fontSize: 12, color: '#666666' }}> RNHostView 会填充原生父级的 100×100 框架。 </Text> <Row style={{ width: 100, height: 100 }}> <RNHostView> <View style={{ flex: 1, backgroundColor: '#9B59B6', borderRadius: 10, margin: 4 }} /> </RNHostView> </Row> </Column> <Column spacing={8}> <Text textStyle={{ fontSize: 18, fontWeight: 'bold' }}>匹配子级尺寸</Text> <Text textStyle={{ fontSize: 12, color: '#666666' }}> RNHostView 会收缩以包裹其 50×50 的子节点。 </Text> <Row style={{ padding: 8 }}> <RNHostView matchContents> <View style={{ width: 50, height: 50, backgroundColor: '#9B59B6', borderRadius: 10 }} /> </RNHostView> </Row> </Column> </Column> </Host> ); }

API

import { RNHostView } from '@expo/ui';

Component

RNHostView

Android
iOS
Web

Type: React.Element<RNHostViewProps>

Hosts React Native views inside Jetpack Compose or SwiftUI views.

Props for the RNHostView component.

RNHostViewProps

children

Android
iOS
Web
Type: ReactElement

The React Native view to host.

disabled

Android
iOS
Web
Optional • Type: boolean

Whether the component is disabled. Disabled components do not respond to user interaction.

hidden

Android
iOS
Web
Optional • Type: boolean

Whether the component is hidden.

matchContents

Android
iOS
Optional • Type: boolean • Default: false

When true, the host updates its size in the native view tree to match the children's size. When false, the host uses the size of the parent native view.

Can only be set once on mount; changing it remounts the component.

modifiers

Android
iOS
Optional • Type: ModifierConfig[]

Platform-specific modifier escape hatch. Pass an array of modifier configs from @expo/ui/swift-ui/modifiers or @expo/ui/jetpack-compose/modifiers.

onAppear

Android
iOS
Web
Optional • Type: () => void

Called when the component appears on screen.

onDisappear

Android
iOS
Web
Optional • Type: () => void

Called when the component is removed from screen.

onPress

Android
iOS
Web
Optional • Type: () => void

Called when the component is pressed.

style

Android
iOS
Web
Optional • Type: Pick<ViewStyle, 'padding' | 'paddingHorizontal' | 'paddingVertical' | 'paddingTop' | 'paddingBottom' | 'paddingLeft' | 'paddingRight' | 'backgroundColor' | 'borderRadius' | 'borderWidth' | 'borderColor' | 'opacity' | 'width' | 'height'>

Platform-agnostic style properties. These are translated to SwiftUI modifiers on iOS and Jetpack Compose modifiers on Android.

testID

Android
iOS
Web
Optional • Type: string

Identifier used to locate the component in end-to-end tests.