React Native的導(dǎo)航:React-Navigation

React Navigation

React Navigation是一個(gè)用于提供React Native導(dǎo)航功能的框架,框架使用了RN的原生接口,所以不需要native端再額外引入依賴(lài)。React Navigation并沒(méi)有使用iOS或者安卓原生的導(dǎo)航系統(tǒng),而是選擇自己實(shí)現(xiàn)。
React Navigation也是使用棧的方式管理頁(yè)面的展示和轉(zhuǎn)場(chǎng),提供手勢(shì)和動(dòng)畫(huà)支持。

創(chuàng)建導(dǎo)航

下面先介紹最常用的導(dǎo)航:createStackNavigator
createStackNavigator是一個(gè)方法,內(nèi)部返回的React組件。所以可以作為App.js的根組件。
API定義:createStackNavigator(RouteConfigs, StackNavigatorConfig);

createStackNavigator分析

內(nèi)部需要兩個(gè)參數(shù):RouteConfigs和StackNavigatorConfig。

配置路由

路由對(duì)象是通過(guò)路由名稱(chēng)和配置的映射 ,告訴導(dǎo)航需要在路由中展現(xiàn)的內(nèi)容。

  // For each screen that you can navigate to, create a new entry like this:
  Profile: {
    // `ProfileScreen` is a React component that will be the main content of the screen.
    screen: ProfileScreen,
    // When `ProfileScreen` is loaded by the StackNavigator, it will be given a `navigation` prop.

    // Optional: When deep linking or using react-navigation in a web app, this path is used:
    path: 'people/:name',
    // The action and route params are extracted from the path.

    // Optional: Override the `navigationOptions` for the screen
    navigationOptions: ({ navigation }) => ({
      title: `${navigation.state.params.name}'s Profile'`,
    }),
  },

  ...MyOtherRoutes,
});

可以設(shè)置多個(gè)路由,并且通過(guò)StachNavigatorConfig內(nèi)的屬性配置默認(rèn)參數(shù)。

在一個(gè)路由內(nèi),可以通過(guò)navigationOptions來(lái)定制導(dǎo)航的樣式,下面分析一下各個(gè)屬性。
title:導(dǎo)航的標(biāo)題。
header:類(lèi)型是React元素。如果設(shè)置了該屬性,默認(rèn)丟棄了原有導(dǎo)航,故設(shè)置的其他屬性都不再生效。
headerBackImage:類(lèi)型是React元素。用于自定義返回按鈕。
headerStyle:用于配置header的樣式。
headerTitleStyle:配置標(biāo)題樣式,例如字體,顏色等。
headerBackground:導(dǎo)航的背景圖片。

路由跳轉(zhuǎn)

跳轉(zhuǎn)
在路由顯示的組件內(nèi),可以調(diào)用一下代碼進(jìn)行跳轉(zhuǎn):

this.props.navigation.navigate('RouteName')

每個(gè)screen組件都會(huì)默認(rèn)創(chuàng)建一個(gè)navigation屬性。之后可以調(diào)用navigate("RouteName")方法來(lái)跳轉(zhuǎn)。(只能跳轉(zhuǎn)到我們已經(jīng)在導(dǎo)航棧內(nèi)定義過(guò)的路由,如果沒(méi)有定義過(guò),則以上方法無(wú)效)。
navigate方法,如果已經(jīng)在A界面,再使用navigate跳轉(zhuǎn)A,會(huì)被系統(tǒng)視為無(wú)效,我們可以使用push方法代替。每次調(diào)用push會(huì)在當(dāng)前導(dǎo)航棧增加新路由。

返回
導(dǎo)航默認(rèn)會(huì)幫我們?cè)黾右粋€(gè)返回按鈕,點(diǎn)擊時(shí)系統(tǒng)會(huì)處理返回事件。如果想主動(dòng)觸發(fā)可以使用this.props.navigation.goBack()
如果想處理多級(jí)返回的情況,比如從Home跳轉(zhuǎn)了很多界面,想返回Home的話可以使用navigate('Home')(注意不是pushpush會(huì)創(chuàng)建并在導(dǎo)航棧添加新的路由,navigate是展示已經(jīng)注冊(cè)的導(dǎo)航棧內(nèi)的頁(yè)面)。或者使用navigation.popToTop()

導(dǎo)航的生命周期

我們前面說(shuō)到了頁(yè)面之間的跳轉(zhuǎn),那么在A跳轉(zhuǎn)到B時(shí),A會(huì)發(fā)生什么變化,在返回時(shí)又會(huì)如何處理?
如果一個(gè)導(dǎo)航棧包含A B兩個(gè)頁(yè)面,當(dāng)顯示A時(shí),A的componentDidMount會(huì)被調(diào)用,當(dāng)push B時(shí),B的componentDidMount會(huì)被調(diào)用。A不會(huì)調(diào)用componentWillUnmount
當(dāng)從B返回A時(shí),B的componentWillUnmount會(huì)被調(diào)用,A的componentDidMount不會(huì)被調(diào)用,因?yàn)锳一直在掛載狀態(tài)中。
知道了生命周期方法調(diào)用細(xì)節(jié)后,我們回歸最開(kāi)始的問(wèn)題,如何知道頁(yè)面的離開(kāi)和返回狀態(tài)呢?
React Navigation對(duì)屏幕組件嵌入了四個(gè)訂閱方法:willFocus,willBlur,didFocus,didBlur。點(diǎn)擊focus/blur API了解更多。

設(shè)置默認(rèn)的導(dǎo)航樣式

上面提到的做法是在每個(gè)路由配置內(nèi)去設(shè)置每個(gè)頁(yè)面的導(dǎo)航,一般情況下,我們多個(gè)頁(yè)面的導(dǎo)航的樣式都是一致的,如果設(shè)置默認(rèn)的導(dǎo)航樣式呢?需要在StackNavigatorConfig內(nèi)通過(guò)屬性defaultNavigationOptions來(lái)設(shè)置:

const RootStack = createStackNavigator(
  {
    Home: HomeScreen,
    Details: DetailsScreen,
  },
  {
    initialRouteName: 'Home',
    /* The header config from HomeScreen is now here */
    defaultNavigationOptions: {
      headerStyle: {
        backgroundColor: '#f4511e',
      },
      headerTintColor: '#fff',
      headerTitleStyle: {
        fontWeight: 'bold',
      },
    },
  }
);

通過(guò)屬性defaultNavigationOptions就可以設(shè)置導(dǎo)航的默認(rèn)樣式。
如果想重載默認(rèn)樣式,還可以在navigationOptions內(nèi)去設(shè)置,會(huì)對(duì)自定義和默認(rèn)進(jìn)行合并,自定義優(yōu)先級(jí)高于defaultNavigationOptions。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,797評(píng)論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,179評(píng)論 3 414
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 175,628評(píng)論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 62,642評(píng)論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,444評(píng)論 6 405
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 54,948評(píng)論 1 321
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,040評(píng)論 3 440
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 42,185評(píng)論 0 287
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,717評(píng)論 1 333
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,602評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,794評(píng)論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,316評(píng)論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,045評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 34,418評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 35,671評(píng)論 1 281
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,414評(píng)論 3 390
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,750評(píng)論 2 370

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

  • 隨著React Navigation逐漸穩(wěn)定,Navigator也被光榮的退休了。在React Native生態(tài)環(huán)...
    CrazyCodeBoy閱讀 1,831評(píng)論 1 10
  • 本文是基于最新的react-navigation^2.9.1來(lái)書(shū)寫(xiě)的。 要感謝掛著鈴鐺的兔看到一篇不錯(cuò)的介紹,這里...
    HT_Jonson閱讀 900評(píng)論 0 52
  • 一. Hello Mobile Navigation 讓我們使用React Naviation來(lái)創(chuàng)建一個(gè)簡(jiǎn)單的聊天...
    nimw閱讀 705評(píng)論 0 1
  • 遇見(jiàn)更新 更新更新更新…,它總是時(shí)時(shí)地的出現(xiàn)在人們的生活里,當(dāng)然了這也是隨著時(shí)間的推移...
    優(yōu)游球閱讀 212評(píng)論 0 1
  • 人一走,茶就涼,是自然規(guī)律;人沒(méi)走,茶就涼,是世態(tài)炎涼。一杯茶, 佛門(mén)看到的是禪,道家看到的是氣,儒家看到的是禮,...
    兜兜冇餹閱讀 163評(píng)論 0 0