React Navigation 5.x goBack 返回并刷新頁面

我們經(jīng)常會有返回上一頁并刷新上頁數(shù)據(jù)的功能需求镣典,比如在表單修改完數(shù)據(jù)再返回信息展示頁。在React Native結(jié)合React Navigation 5.x開發(fā)的應用中兄春,我們可以這樣實現(xiàn):

A頁面跳轉(zhuǎn)B頁面時赶舆,在params加上一個值為更新A頁面方法的參數(shù):navigation.navigate('A', { update: () => updateFun()}) }
要從B頁面返回A頁面時,先從路由參數(shù)中獲取這個方法并執(zhí)行芜茵,再返回。
route.params.update()
navigation.goBack()

簡單示例如下:

這是信息展示頁 UserCenter

// 用戶信息展示頁
import React from 'react'
import { View, Button } from 'react-native'

const UserCenter = (props) => {
  const updateData = () => {
    // ... 這里寫更新頁面的邏輯绞佩,比如重新請求
    console.warn('更新數(shù)據(jù)啦')
  }
  return (
    <View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}>
      <Button
        title="去用戶編輯頁"
        onPress={() => props.navigation.navigate('UserEdit', {update: updateData})}
      />
    </View>
}
export default UserCenter

這是信息編輯頁 UserEdit

// 用戶信息編輯頁
import React from 'react'
import { View, Button, Alert } from 'react-native'
import { editUser } from '@api/user'

const UserEdit = (props) => {
  // 組件狀態(tài)信息省略
  const [editInfo, setEditInfo] = useState({......})

  const submitEdit = async () => {
    // 具體提交請求省略
    const result = await editUser(userId, editInfo)
    if(result.code === 200) {
      Alert.alert(result.message)
      // 路由參數(shù) update 的值即是在 UserCenter 組件中定義的 updateData 方法品山,我們直接執(zhí)行它
      route.params.update() 
      navigation.goBack() // 返回上一頁
    }
  }
  return (
    <View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}>
      <Button
        title="確認修改"
        onPress={submitEdit}
      />
    </View>
}
export default UserEdit

注意:在路由參數(shù)內(nèi)傳遞不可序列化的值(如實例烤低、函數(shù)等)會報一個警告??:Non-serializable values were found in the navigation state,因為這可能會破壞其他功能扑馁,例如狀態(tài)持久性,深層鏈接等魄懂。

如果你不使用狀態(tài)持久性或不使用接受參數(shù)形式的屏幕的深層鏈接闯第,則可以放心地忽略它。

或者我們安全起見用以下方法:官網(wǎng)鏈接??:傳遞參數(shù)到上一個屏幕
如果目標屏幕已經(jīng)存在于歷史記錄中咳短,我們要實現(xiàn)返回并傳參可以使用navigate來代替goBack。這種情況navigategoBack的作用是一樣的篡腌。

為什么它倆可以一樣呢勾效?
順便加深理解下navigatepush的區(qū)別:使用navigate導航到一個已經(jīng)存在于歷史記錄的屏幕的效果是:返回到這個屏幕并刪除在這屏之后的所有記錄叛甫。navigate永遠不會重復推送相同的屏幕到歷史記錄里杨伙。要實現(xiàn)重復推送,例如傳不同id就表示不同屏幕的詳情頁組件限匣,我們導航的時候必須要用push

import React, { useEffect } from 'react'
import { View, Button } from 'react-native'

function UserCenter({ navigation, route }) {
  useEffect(() => {
    if (route.params?.refresh) {
      // 如果拿到了更新參數(shù)锌历,即表示需要刷新
      // 這里書寫更新邏輯
      console.warn(route.params.refresh)
    }
  }, [route.params?.refresh])

  return (
    <View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}>
      <Button
        title="去用戶編輯頁"
        onPress={() => navigation.navigate('UserEdit')}
      />
    </View>
  );
}

function UserEdit({ navigation, route }) {
  // 組件狀態(tài)信息省略
  const [editInfo, setEditInfo] = useState({......})

  const submitEdit = async () => {
    // 具體提交請求省略
    const result = await editUser(userId, editInfo)
    if(result.code === 200) {
      Alert.alert(result.message)
      // 傳遞個表示要刷新的路由參數(shù)即可峦筒,為了參數(shù)每次變化,我們傳個隨機數(shù) 
      navigation.navigate('User', { refresh: Math.random() })
    }
  }
  return (
    <View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}>
      <Button
        title="確認修改"
        onPress={submitEdit}
      />
    </View>
  );
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末捉邢,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子伏伐,更是在濱河造成了極大的恐慌,老刑警劉巖藐翎,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吝镣,死亡現(xiàn)場離奇詭異,居然都是意外死亡末贾,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門辉川,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拴测,“玉大人,你說我怎么就攤上這事屿愚。” “怎么了渺鹦?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長塞颁。 經(jīng)常有香客問我吸耿,道長,這世上最難降的妖魔是什么咽安? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任妆棒,我火速辦了婚禮,結(jié)果婚禮上糕珊,老公的妹妹穿的比我還像新娘。我一直安慰自己澜公,他們只是感情好,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布坟乾。 她就那樣靜靜地躺著蝶防,像睡著了一般。 火紅的嫁衣襯著肌膚如雪殷费。 梳的紋絲不亂的頭發(fā)上菱鸥,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天,我揣著相機與錄音殷绍,去河邊找鬼。 笑死主到,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的登钥。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼看锉,長吁一口氣:“原來是場噩夢啊……” “哼塔鳍!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起轮纫,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤掌唾,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后糯彬,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡叽粹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年却舀,在試婚紗的時候發(fā)現(xiàn)自己被綠了锤灿。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡螃诅,死狀恐怖状囱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情亭枷,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布猾编,位于F島的核電站,受9級特大地震影響答倡,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜获茬,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一倔既、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧叉存,春花似錦、人聲如沸稿存。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽练俐。三九已至,卻和暖如春燕锥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背归形。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工鼻由, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蔼紧。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓狠轻,卻偏偏與公主長得像,于是被迫代替她去往敵國和親哈误。 傳聞我的和親對象是個殘疾皇子躏嚎,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內(nèi)容