react-native (三 - 上) : Navigator

大家學(xué)習(xí)完了一些常用組件的應(yīng)用及其布局,現(xiàn)在我們來了解一個單頁面app才有的導(dǎo)航navigation

react-native version < 0.44.0版本之前提供了Navigator來制作導(dǎo)航因宇,之后版本若還需要用這個導(dǎo)航請額外添加react-native-deprecated-custom-components 來使用navigator,官方不會再進行維護

react-native version >= 0.44.0 官方推薦使用react-navigation

navigator

我們打開src/Root/root.js

我們看到這個Navigator組件在這里賦值使用了三個屬性次兆,initialRoute,configureScene和renderScene翔冀,當然Navigator的屬性遠不止這些摊阀,了解navigator的屬性

InitialRoute

The initial route for navigation. A route is an object that the navigator?will use to identify each scene it renders.?If both `initialRoute` and `initialRouteStack` props are passed to `Navigator`, then `initialRoute` must be in a route in `initialRouteStack`. If `initialRouteStack` is passed as a prop but `initialRoute` is not, then `initialRoute` will default internally to??the last item in `initialRouteStack`.

上面是官方給的解釋人断,對于我們來說我們需要認識到initialRoute是一個對象吭从,而這個對象是用來呈現(xiàn)呈現(xiàn)最終場景的氛濒,也就是我們能看到的那個場景.(不著急假褪,我們等會再聊initialRouteStack

看到我們的root.js里面的程序,我們定義了一個全局的initialRoute對象漱牵,這個對象里面包含了兩個屬性:id和params,我想說的是步做,這個兩個屬性并不是必須的副渴,其實initialRoute對象的構(gòu)造都是用戶根據(jù)自己的需求自定義的∪龋可能你當前路由的界面需要一個頁面名字佳晶,那么你可以添加一個屬性title,你想為路由的頁面?zhèn)鬟f參數(shù)你可以添加一個屬性名叫params或者props讼载。

我們現(xiàn)在初始化好了initialRoute并且將他賦值到了Navigator元素上的initialRoute屬性里,告訴組件我現(xiàn)在初始化要展示的頁面我需要的東西都在了中跌! 那么Navigator是怎么做到關(guān)聯(lián)到具體的對象的呢咨堤?

renderScene

Required function which renders the scene for a given route. Will be invoked with the `route` and the `navigator` object. (route, navigator) =>

按照官方的解釋,這個屬性是個方法漩符,而這個方式是用來展示你用戶所給的路由的一喘,而且它會默認傳遞一個navigator對象。

現(xiàn)在請大家注釋掉我們的initialRoute這個全局對象嗜暴,我們重新定義一個新的初始化路由


我們只需要在這個路由里面添加一個component屬性并且把login組件賦值到屬性上去


再修改下我們renderScene的函數(shù)體凸克,讓它返回一個route.component。然后運行項目看看結(jié)果會怎么樣闷沥。其實大家肯定也已經(jīng)猜到萎战,我們initialRoute對象在這里被當作是了route傳遞到了renderScene方法中,為了驗證我們的猜想舆逃,我們打開瀏覽器的調(diào)試工具進行斷點調(diào)試 蚂维。?如何調(diào)試?


看到了么路狮?事實正如我們所猜測的一樣虫啥,我們這個route里面剛好有一個屬性叫Component,并且它是一個login組件奄妨。從而我們又可以大膽的猜測涂籽,我們renderScene函數(shù)是用來返回我們的組件的,至于怎么返回我們可以自己定義砸抛,并且我們還可以操作到當前的navigator這個組件评雌。大家可以多多練習(xí),多多調(diào)試看看具體情況直焙。

configureScene

Optional function where you can configure scene animations and gestures. Will be invoked with `route` and `routeStack` parameters, where `route` corresponds to the current scene being rendered by the `Navigator` and `routeStack` is the set of currently mounted routes?that the navigator could transition to. The function should return a scene configuration object. (route, routeStack) => Navigator.SceneConfigs.FloatFromRight

官方解釋來看柳骄,這個函數(shù)是optional,這代表著這個屬性不是必須賦值的箕般。而這個函數(shù)是用來干嘛的耐薯?用來處理場景的動畫和手勢。它會要求兩個參數(shù)route和routestack,route如同renderScene中的route一樣是將要處理的界面的路由曲初,routestack則是界面跳轉(zhuǎn)關(guān)系的集合体谒。(大膽猜測下,routestack是不是我們initialStack的產(chǎn)物)

同樣如果你僅僅是想控制導(dǎo)航的動畫可以直接配置枚舉臼婆,你依然可以對routestack進行操作抒痒。


initialRouteStack

?Pass this in to provide a set of routes to initially mount. This prop is required if `initialRoute` is not provided to the navigator. If this prop is not passed in, it will default internally to an array containing only `initialRoute`.

我們猜對了么?


模塊與模塊之間的調(diào)用 (持續(xù)更新....腦子不好使了慢慢寫.)

這里順便想解釋下weguess的模塊調(diào)用的設(shè)計颁褂。僅僅是擴展故响,若想繼續(xù)學(xué)習(xí)新的組件用法

react-native (三 - 下)react-navigation

其實對于app而言,模塊與模塊之間的調(diào)用一直是一個值得關(guān)注的問題颁独。為什么彩届?現(xiàn)在的app做的越來越大,涵蓋的東西越來越多誓酒,我們是應(yīng)該不停的往一個程序里面添加內(nèi)容么樟蠕?答案肯定是否定的,我們應(yīng)該只將需要的功能裝入app中靠柑,于是我們把app分成了企業(yè)版和專業(yè)版解決了我們的矛盾寨辩。突然有一天,你老總氣急敗壞的告訴你歼冰,你的操作失誤導(dǎo)致專業(yè)版的數(shù)據(jù)出現(xiàn)混亂造成損失靡狞,這個時候你無比的意識到可能你用的專業(yè)版和老板的應(yīng)該又是兩個不同的分支。然后又開始頭痛app的權(quán)限和所涉獵的包大小的問題隔嫡。

解決方式:功能模塊化

我想了很久應(yīng)該具體給這個方法叫什么名字耍攘。最后字面意思,我們應(yīng)該把我們的功能模塊化畔勤,什么叫模塊化蕾各?也就是我這個功能從app內(nèi)部邏輯獨立出來,模塊給出interface庆揪,我們只需要按照模塊的需求傳遞參數(shù)和匿名函數(shù)式曲。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市缸榛,隨后出現(xiàn)的幾起案子吝羞,更是在濱河造成了極大的恐慌,老刑警劉巖内颗,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件钧排,死亡現(xiàn)場離奇詭異,居然都是意外死亡均澳,警方通過查閱死者的電腦和手機恨溜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門符衔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人糟袁,你說我怎么就攤上這事判族。” “怎么了项戴?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵形帮,是天一觀的道長。 經(jīng)常有香客問我周叮,道長辩撑,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任仿耽,我火速辦了婚禮合冀,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘氓仲。我一直安慰自己,他們只是感情好得糜,可當我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布敬扛。 她就那樣靜靜地躺著,像睡著了一般朝抖。 火紅的嫁衣襯著肌膚如雪啥箭。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天治宣,我揣著相機與錄音急侥,去河邊找鬼。 笑死侮邀,一個胖子當著我的面吹牛坏怪,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播绊茧,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼铝宵,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了华畏?” 一聲冷哼從身側(cè)響起鹏秋,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎亡笑,沒想到半個月后侣夷,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡仑乌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年百拓,在試婚紗的時候發(fā)現(xiàn)自己被綠了琴锭。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡耐版,死狀恐怖祠够,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情粪牲,我是刑警寧澤古瓤,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站腺阳,受9級特大地震影響落君,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜亭引,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一绎速、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧焙蚓,春花似錦纹冤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至宏浩,卻和暖如春知残,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背比庄。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工求妹, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人佳窑。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓制恍,卻偏偏與公主長得像,于是被迫代替她去往敵國和親神凑。 傳聞我的和親對象是個殘疾皇子吧趣,可洞房花燭夜當晚...
    茶點故事閱讀 44,713評論 2 354

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