欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React-Native中禁用Navigator手勢返回的示例代碼

 更新時間:2017年09月09日 09:35:45   作者:蘇小敗在路上  
本篇文章主要介紹了React-Native中禁用Navigator手勢返回的示例代碼,具有一定的參考價值,有興趣的可以了解一下

在React-Native開發(fā)中,經(jīng)常會用到導(dǎo)航。導(dǎo)航做什么用的呢,簡單點說就是頁面跳轉(zhuǎn)。

個項目中,肯定有很多的頁面要跳來跳去的,RN就給我們提供了Navigator組件,可以很好的管理頁面的跳轉(zhuǎn)。

在所有工作做完之后,發(fā)現(xiàn)有個bug!在從第一個界面跳轉(zhuǎn)到下一個界面后,如果從屏幕左邊向右滑,或者從上面想下滑,你會發(fā)現(xiàn)一個神奇的事情,那就是頁面會通過滑動而返回到上一個界面。這讓我們很尷尬了,本來打算禁止跳轉(zhuǎn)返回的,或者返回時還要做些什么處理的,結(jié)果啥都沒做,直接返回,可以說,這個功能有點適得其反了。

于是為了解決這個問題,到處找答案,官網(wǎng)沒有說,論壇也沒人回答。于是放置了很久很久,沒想到在今天的而然查找下,終于找到解決方案了。

方案主要分三種:

1,自己定義個configureScene:

const NoBackSwipe = { 
 ...Navigator.SceneConfigs.HorizontalSwipeJump, 
  gestures: { 
   pop: {} 
  } 
}; 

然后在Navigator標簽下使用

<Navigator  
   initialRoute={{Component:'xxx', name:'xxx', index:0, configure: NoBackSwipe}} 
   renderScene={this.renderScene.bind(this)} 
   configureScene={(route,routeStack)=>{ 
    return NoBackSwipe 
   }} 
  /> 

這里主要是處理了pop,其中還有jumpback,jumpforward的

2,如果你都不要返回處理的,直接將gestures都改成{}或者null

configureScene(route, routeStack){ 
 let configure = Navigator.SceneConfigs.PushFromRight; 
 switch(route.configure){ 
  case Consts.FloatFromLeft: 
   configure = Navigator.SceneConfigs.FloatFromLeft; 
   break; 
  case Consts.FloatFromBottom: 
   configure = Navigator.SceneConfigs.FloatFromBottom; 
   break; 
 } 
 return { 
  ...configure, 
  gestures:{}//或者改成null 
 }; 
} 

然后使用也是一樣: 

<Navigator initialRoute={{Component:'xxx', name:'xxx', index:0, configure: NoBackSwipe}} 
    configureScene={this.configureScene.bind(this)} 
    renderScene={this.renderScene.bind(this)} 
    onStartShouldSetResponder={()=>false}/> 

我就是用的第二種。

3,還有一種,是直接改源碼,在項目目錄下找到路徑:

/node_modules/react-native/Libraries/CustomComponents/Navigator/Navigator.js

里面有一段代碼,去掉pop就可以了

var GESTURE_ACTIONS = [ 
 'pop',//把這個去掉就可以了 
 'jumpBack', 
 'jumpForward', 
]; 

這種直接修改源碼的不推薦使用,因為每當你要升級RN或者做其他調(diào)整時,重新下載下來又得改,還是上面兩種比較靠譜。

以上就是今天的大發(fā)現(xiàn),終于解決滑動返回的問題了~

資料參考:How to disable back swipe gesture in react native navigator

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • useEffect中return函數(shù)的作用和執(zhí)行時機解讀

    useEffect中return函數(shù)的作用和執(zhí)行時機解讀

    這篇文章主要介紹了useEffect中return函數(shù)的作用和執(zhí)行時機,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • react實現(xiàn)antd線上主題動態(tài)切換功能

    react實現(xiàn)antd線上主題動態(tài)切換功能

    這篇文章主要介紹了react實現(xiàn)antd線上主題動態(tài)切換功能,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • webpack打包react項目的實現(xiàn)方法

    webpack打包react項目的實現(xiàn)方法

    這篇文章主要介紹了webpack打包react項目的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • 淺談React多個setState會調(diào)用幾次

    淺談React多個setState會調(diào)用幾次

    在React的生命周期鉤子和合成事件中,多次執(zhí)行setState,會被調(diào)用幾次,本文就詳細的介紹一下,感興趣的可以了解一下
    2021-11-11
  • React中的生命周期詳解

    React中的生命周期詳解

    這篇文章主要介紹了React中的生命周期,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-09-09
  • react-router-dom之異步加載路由方式

    react-router-dom之異步加載路由方式

    這篇文章主要介紹了react-router-dom之異步加載路由方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 用React實現(xiàn)一個類 chatGPT 的交互式問答組件的方法詳解

    用React實現(xiàn)一個類 chatGPT 的交互式問答組件的方法詳解

    這篇文章主要給大家詳細介紹如何用React實現(xiàn)一個類 chatGPT 的交互式問答組件的方法,文中有詳細的代碼示例,對我們學(xué)習(xí)有一定的幫助,需要的朋友可以參考下
    2023-06-06
  • 通過示例講解Remix?設(shè)計哲學(xué)理念

    通過示例講解Remix?設(shè)計哲學(xué)理念

    這篇文章主要為大家通過示例講解了Remix?設(shè)計哲學(xué)理念,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • 詳解React中的setState執(zhí)行機制

    詳解React中的setState執(zhí)行機制

    setState是React組件中用于更新狀態(tài)的方法,是類組件中的方法,用于更新組件的狀態(tài)并重新渲染組件,本文給大家詳細介紹了React中的setState執(zhí)行機制,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • React報錯之組件不能作為JSX組件使用的解決方法

    React報錯之組件不能作為JSX組件使用的解決方法

    本文主要介紹了React報錯之組件不能作為JSX組件使用的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07

最新評論