尺寸
信息
useWindowDimensions 是 React 组件的首选 API。与 Dimensions 不同,它会随着窗口尺寸更新而更新。这与 React 范式很好地配合。
tsx
import {Dimensions} from 'react-native';
您可以使用以下代码获取应用窗口的宽度和高度:
tsx
const windowWidth = Dimensions.get('window').width;
const windowHeight = Dimensions.get('window').height;
备注
虽然尺寸立即可用,但它们可能会发生变化(例如由于设备旋转、折叠设备等),因此任何依赖于这些常量的渲染逻辑或样式都应尝试在每次渲染时调用此函数,而不是缓存该值(例如,使用内联样式而不是在 StyleSheet 中设置值)。
如果您针对折叠设备或可以更改屏幕尺寸或应用窗口尺寸的设备,您可以使用 Dimensions 模块中提供的事件监听器,如下例所示。
示例
参考
方法
addEventListener()
tsx
static addEventListener(
type: 'change',
handler: ({
window,
screen,
}: DimensionsValue) => void,
): EmitterSubscription;
添加一个事件处理器。支持的事件:
change: 当Dimensions对象内的属性发生变化时触发。事件处理程序的参数是一个DimensionsValue类型的对象。
get()
tsx
static get(dim: 'window' | 'screen'): ScaledSize;
初始尺寸在调用 runApplication 之前设置,因此它们在任何其他 require 运行之前应该可用,但可能会稍后更新。
示例:const {height, width} = Dimensions.get('window');
参数:
| Name | Type | Description |
|---|---|---|
| dim 必需 | string | 调用 set 时定义的维度名称。返回该维度的值。 |
备注
对于 Android,window 尺寸将减去状态栏的大小(如果不是半透明的)和底部导航栏的大小。
类型定义
DimensionsValue
属性:
| Name | Type | Description |
|---|---|---|
| window | ScaledSize | 可见应用窗口的大小。 |
| screen | ScaledSize | 设备屏幕的大小。 |
ScaledSize
| Type |
|---|
| object |
属性:
| Name | Type |
|---|---|
| width | number |
| height | number |
| scale | number |
| fontScale | number |