react-native-safe-area-context

react-native-safe-area-context

React Native多平台安全区域管理库

react-native-safe-area-context是一个用于管理多平台安全区域的React Native库。它提供SafeAreaProvider、SafeAreaView组件和useSafeAreaInsets钩子,帮助开发者适配不同设备的屏幕尺寸和系统元素。支持Android、iOS、Web、macOS和Windows平台,具有初始渲染优化功能和Jest测试支持。该库简化了跨平台应用开发中的安全区域处理过程。

react-nativeSafeAreaProviderSafeAreaView安全区域跨平台Github开源项目

react-native-safe-area-context

npm Supports Android, iOS, web, macOS and Windows MIT License

JavaScript tests iOS build Android build

一种灵活的处理安全区域的方式,在Android和Web上也适用!

入门指南

npm install react-native-safe-area-context
yarn add react-native-safe-area-context

然后你需要为你所使用的平台链接库的原生部分。

  • iOS 平台:

    $ npx pod-install

支持的 react-native 版本

版本react-native 版本
4.0.0+0.64.0+

新架构支持

这个库目前对新的 react-native 架构有实验性支持。请注意,将会有重大变更,并且只支持最新版本的 react-native。

您需要使用 4.4.0 和 react-native 0.70+。

使用

这个库有两个重要的概念,如果你熟悉 React 上下文,这很类似。

提供者

SafeAreaProvider组件是一个 View,其中由消费者提供的内边距是相对于该 view 的。这意味着,如果这个 view 与任何系统元素(状态栏、凹槽等)重叠,这些值将被提供给后代消费者。通常,您将在应用程序的顶部有一个提供者。

消费者

消费者是组件和钩子,允许使用最近的父Provider提供的内边距值。这些值总是相对于提供者,而不是这些组件。

  • SafeAreaView是首选的消费方式。这是一个带有应用内边距的常规 View。它通过本地应用内边距获得更好的性能,并避免了使用其他基于 JS 的消费者可能出现的闪烁。

  • useSafeAreaInsets提供更多灵活性,但在某些情况下可能会导致一些布局闪烁。如果您需要更多地控制内边距的应用方式,请使用它。

API

SafeAreaProvider

您应该在应用程序的根组件中添加 SafeAreaProvider。当使用 react-native-screens时,您可能需要在其他地方添加它,如模态和路由的根部。

请注意,提供者不应该在用 Animated 动画的 View 内部或 ScrollView 内部,因为这可能导致非常频繁的更新。

示例

import { SafeAreaProvider } from 'react-native-safe-area-context'; function App() { return <SafeAreaProvider>...</SafeAreaProvider>; }

属性

接受所有 View属性。默认样式为 {flex: 1}

initialMetrics

可选的,默认为 null

可用于提供帧和内边距的初始值,这样可以立即渲染。有关如何使用此属性的更多信息,请参见优化

SafeAreaView

SafeAreaView 是一个常规的 View 组件,其安全区域内边距被应用为填充或边距。

填充或边距样式会添加到内边距中,例如在具有 20 个内边距的 SafeAreaView 上设置 style={{paddingTop: 10}} 将导致顶部填充为 30。

示例

import { SafeAreaView } from 'react-native-safe-area-context'; function SomeComponent() { return ( <SafeAreaView style={{ flex: 1, backgroundColor: 'red' }}> <View style={{ flex: 1, backgroundColor: 'blue' }} /> </SafeAreaView> ); }

属性

接受所有 View属性。

edges

可选的,toprightbottomleft的数组。默认为全部。

设置应用安全区域内边距的边缘。

例如,如果您不想将内边距应用于顶部边缘,因为该视图不接触屏幕顶部,您可以使用:

<SafeAreaView edges={['right', 'bottom', 'left']} />

它还可以设置为一个对象 { top?: EdgeMode, right?: EdgeMode, bottom?: EdgeMode, left?: EdgeMode },其中 EdgeMode = 'off' | 'additive' | 'maximum'。 Additive 是默认模式,和传递边缘数组是一样的: finalPadding = safeArea + padding。最大模式将使用安全区域内边距或填充/边距(取决于 mode)如果安全区域小于则: finalPadding = max(safeArea, padding)。例如,如果您想要一个浮动的 UI 元素,应该位于底部安全区域边缘上的设备上,或者如果安全区域小于 24px 则位于屏幕底部 24px 处:

<SafeAreaView style={{paddingBottom: 24}} edges={{bottom: 'maximum'}} />
mode

可选的,'填充'(默认)或'边距'。

将安全区域应用于填充或边距。

这对于创建感知安全区域的分隔组件很有用,例如:

<SafeAreaView mode="margin" style={{ height: 1, backgroundColor: '#eee' }} />

useSafeAreaInsets

返回最近提供程序的安全区域内插值。这允许从JavaScript操纵插入值。请注意,插入值不会同步更新,因此在旋转屏幕时可能会导致轻微延迟。

对象包含 { top: number, right: number, bottom: number, left: number }

import { useSafeAreaInsets } from 'react-native-safe-area-context'; function HookComponent() { const insets = useSafeAreaInsets(); return <View style={{ paddingBottom: Math.max(insets.bottom, 16) }} />; }

useSafeAreaFrame

返回最近提供程序的框架。这可以作为 Dimensions 模块的替代方法使用。

对象包含 { x: number, y: number, width: number, height: number }

SafeAreaInsetsContext

具有安全区域内插值的React上下文。

可以与类组件一起使用:

import { SafeAreaInsetsContext } from 'react-native-safe-area-context'; class ClassComponent extends React.Component { render() { return ( <SafeAreaInsetsContext.Consumer> {(insets) => <View style={{ paddingTop: insets.top }} />} </SafeAreaInsetsContext.Consumer> ); } }

withSafeAreaInsets

高阶组件,提供安全区域内插值作为 insets 属性。

type Props = WithSafeAreaInsetsProps & { someProp: number; }; class ClassComponent extends React.Component<Props> { render() { return <View style={{ paddingTop: this.props.insets.top }} />; } } const ClassComponentWithInsets = withSafeAreaInsets(ClassComponent); <ClassComponentWithInsets someProp={1} />;

SafeAreaFrameContext

具有安全区域框架值的React上下文。

initialWindowMetrics

初始渲染时窗口的内插值和框架。这可以与 SafeAreaProviderinitialMetrics 一起使用。参见优化了解更多信息。

对象包含:

{ frame: { x: number, y: number, width: number, height: number }, insets: { top: number, left: number, right: number, bottom: number }, }

注意: 此值可能为空或过时,因为它是在创建本机模块时计算的。

已弃用的API

useSafeArea

使用 useSafeAreaInsets 代替。

SafeAreaConsumer

使用 SafeAreaInsetsContext.Consumer 代替。

SafeAreaContext

使用 SafeAreaInsetsContext 代替。

initialWindowSafeAreaInsets

使用 initialWindowMetrics 代替。

Web SSR

如果您在Web上进行服务器端渲染,可以使用 initialMetrics 根据用户的设备注入内插值和框架值,或简单地传递零值。由于内插值测量是异步的,否则它将破坏页面内容的呈现。

优化

如果可以,请使用 SafeAreaView。它是本地实现的,因此在旋转设备时,没有来自异步桥接的延迟。

为了加快初始渲染,您可以从此软件包导入 initialWindowMetrics ,并将其作为提供程序上的 initialMetrics 属性设置,如Web SSR中所述。如果您的提供程序重新装载,或者您使用的是 react-native-navigation,则无法这样做。

import { SafeAreaProvider, initialWindowMetrics, } from 'react-native-safe-area-context'; function App() { return ( <SafeAreaProvider initialMetrics={initialWindowMetrics}> ... </SafeAreaProvider> ); }

测试

该库包含一个内置的Jest模拟。它将默认使用以下指标:

{ frame: { width: 320, height: 640, x: 0, y: 0, }, insets: { left: 0, right: 0, bottom: 0, top: 0, }, }

要使用它,请将以下代码添加到jest设置文件中:

import mockSafeAreaContext from 'react-native-safe-area-context/jest/mock'; jest.mock('react-native-safe-area-context', () => mockSafeAreaContext);

为了更好地控制测试值,也可以将 initialMetrics 传递给 SafeAreaProvider 以提供框架和内插值的模拟数据。

export function TestSafeAreaProvider({ children }) { return ( <SafeAreaProvider initialMetrics={{ frame: { x: 0, y: 0, width: 0, height: 0 }, insets: { top: 0, left: 0, right: 0, bottom: 0 }, }} > {children} </SafeAreaProvider> ); }

贡献

请参阅贡献指南

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多