在 React Native 层禁止 iOS 左滑返回(手势返回/手势退出)

在 React Native 层禁止 iOS 左滑返回(手势返回/手势退出)通常有两种方式:

  • 方法 1:在 react-navigation 中配置
  • 如果你用的是 react-navigation(最常见):
javascript 复制代码
import { createStackNavigator } from '@react-navigation/stack';

const Stack = createStackNavigator();

export default function AppNavigator() {
  return (
    <Stack.Navigator>
      <Stack.Screen
        name="Home"
        component={HomeScreen}
        options={{
          // 禁用 iOS 左滑返回手势
          gestureEnabled: false,
        }}
      />
      <Stack.Screen
        name="Detail"
        component={DetailScreen}
        options={{
          gestureEnabled: false,
        }}
      />
    </Stack.Navigator>
  );
}
  • gestureEnabled: false 就能禁止 iOS 左滑返回。
  • 只想在某些页面禁止,就在对应的 Screen 上配置。

方法 2:在 react-native-screens 里配置

如果项目启用了 react-native-screens(enableScreens()),可以在 screen 级别禁用

javascript 复制代码
import { Screen } from 'react-native-screens';

<Screen
  style={{ flex: 1 }}
  gestureEnabled={false} // 禁止左滑
>
  <YourComponent />
</Screen>

方法 3:完全禁止(全局)

如果希望整个 App 都禁用 iOS 左滑:

javascript 复制代码
<Stack.Navigator screenOptions={{ gestureEnabled: false }}>
  {/* 所有页面都禁用左滑 */}
</Stack.Navigator>

gestureEnabled: false 只影响 手势返回,不影响上方返回按钮(导航栏返回箭头)。

如果你还想禁用返回按钮,需要在 headerLeft: () => null 或 headerBackVisible: false 配置。

行为区别

iOS

默认开启左滑返回手势(gestureEnabled: true),设置 false 后禁用。

Android

没有左滑返回手势,Android 返回依赖物理返回键 / 导航栏返回。

所以这个配置在 Android 上 不会有任何影响,不会禁用物理返回键,也不会影响 navigation.goBack()。

推荐且显著有效的:方法一

相关推荐
2501_916007475 小时前
HTTPS 抓包乱码怎么办?原因剖析、排查步骤与实战工具对策(HTTPS 抓包乱码、gzipbrotli、TLS 解密、iOS 抓包)
android·ios·小程序·https·uni-app·iphone·webview
北海-cherish8 小时前
Wouter 和 React Router的区别
前端·react.js·前端框架
!chen9 小时前
学习 React 前掌握 JavaScript 核心概念
javascript·学习·react.js
niusir10 小时前
Zustand 实战:10 行代码搞定全局状态
前端·javascript·react.js
niusir10 小时前
React 状态管理的演进与最佳实践
前端·javascript·react.js
2501_9160088911 小时前
HTTPS 双向认证抓包实战,原理、难点、工具与可操作的排查流程
网络协议·http·ios·小程序·https·uni-app·iphone
2501_9151063211 小时前
HTTPS 能抓包吗?实战答案与逐步可行方案(HTTPS 抓包原理、证书Pinning双向认证应对、工具对比)
网络协议·http·ios·小程序·https·uni-app·iphone
游戏开发爱好者811 小时前
App HTTPS 抓包实战,原理、常见问题与可行工具路线(开发 测试 安全 角度)
网络协议·安全·ios·小程序·https·uni-app·iphone
2501_9151063211 小时前
App HTTPS 抓包实战指南,原理、常见阻碍、逐步排查与工具组合
网络协议·http·ios·小程序·https·uni-app·iphone
OneWind12 小时前
今天发现一个提升图片加载速度的方法就是使用服务器代理
react.js