谈谈我对 RN Navigator的理解

React Native的Navigator,理解起来相对来说不太容易,经过一些实践之后谈谈我的理解。参考的是这篇文章的代码

首先从原理上,Navigator是用来作为组件之间的导航器。而缺乏类似Router性质的东西时,最简单的办法是将下个组件(也叫场景Scene),直接告诉导航器。所以就需要在页面的上面引入下个组件。 另外就是不要忘记引入 Navigator。

export default class SampleComponent extends React.Component {
        render() {
            let defaultName = 'FirstPageComponent';// 第一个要展示的组件
            let defaultComponent = FirstPageComponent;
            return (
            <Navigator
              initialRoute={{ name: defaultName, component: defaultComponent }}
              configureScene={(route) => {
                return Navigator.SceneConfigs.VerticalDownSwipeJump;
              }}
              renderScene={(route, navigator) => {
                let Component = route.component;
                return <Component {...route.params} navigator={navigator} />
              }} />
            );
        }
    } 

initialRoute={{ name: defaultName, component: defaultComponent }}
Navigator实现跳转,是通过Push和Pop方法,相当于是一个数组,每要跳到下个Scene(场景),就把下个页面push到这个数组中,当想要后退的时候,再把这个Pop出去。所以这个数组里存放的肯定是能索引到这个Scene的数据,所以理所应当存放一个Component键是合理的。这里initialRoute的时候除了Component还引入了一个name,这个是可选的,不要也行。
defaultNamedefaultComponent存放的就是你要render的第一个Scene,相当于跳转的起点,不一定是就是要点击的那个组件,但必须是包含在里面的。

configureScene={(route) => { return Navigator.SceneConfigs.VerticalDownSwipeJump; }}

这里定义了跳转的过渡动画,如果你的编辑器支持的话,可以删掉最后一节,看看最其他的选项。
renderScene={(route, navigator) => { let Component = route.component; return <Component {...route.params} navigator={navigator} /> }}
这个段代码执行过后,就将你的“defaultComponent”渲染出来了,其中route.componet就是在initialRoute里写进去的component。
return <Component {...route.params} navigator={navigator} />

渲染了你要展示的第一个页面,还顺便把几个参数写了进去,...route.params这个语法是要展开所有params,现在你initialRoute的时候没有写 params,但是以后在页面之间传递参数的时候就会要写的。假如,InitialRoute的时候写了:

initialRoute={{ name: defaultName, component: defaultComponent params:{ id:123} }}

这就相当于 :

return <Component id={route.params.id} navigator={navigator} />

对,就是这么神奇。你会发现就可以在你渲染的页面里,通过this.props.id找到这个参数了,当然还有后面传入的navigator,你也可以在props中找到。

现在只是刚刚定义好了导航器而已,在现在这个渲染的组件里,找一个可以Touchable开头的组件,在属性里写个onPress={}属性。假设点击这个组件,就要前往下个页面。

此时导航器需要知道下一个Scene是哪里,所以先在头部将需要跳转的Scene引入。

在点击事件的回调函数里,

 _pressButton(id) {
    const {navigator} = this.props;
    if (navigator) {
      navigator.push({
        name: 'StoryTeller',
        component: StoryTeller,
        params: {
          id: id
        }
      })
    }
  }

const {navigator} = this.props; 这么写相当于 const navigator = this.props.navigator

点击事件发生后,需要要把下个Scene给Push到navigator中,同样还有看起来没什么用的name。注意这里同样传了params,在这里不用手动return出来要加载的页面了,navigator会依照之前的模式,直接开始渲染。相当于:
<StoryTeller id={id} name='StoryTeller' navigator={this.props.navigator} />

跳回来,使用的是Pop方法。和Push类似,不过不用写参数:

  onBackAndroid = ()=> {
    const nav = this.props.navigator;
    const routers = nav.getCurrentRoutes();
    if (routers.length > 1) {
      nav.pop();
    }
  };

navigator 对象里最后进去的,一定是当前的页面,所以初始化的时候数组的长度为1,这里有一个判断,当这个数组的=1的时候,就不再跳转,直接执行退出应用。这里适合具有多次点击返回时候(例如安卓返回键),一般的点击返回直接执行navigator的Pop方法即可。

  _pressButton() {
        const { navigator } = this.props;
        if(navigator) {
            navigator.pop();
        }
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • 前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人...
    珍此良辰阅读 7,267评论 33 15
  • 重新排版 理解navigator 这是一个简单的例子,用Navigator来跳转页面,页面之间传递参数 (代码是E...
    lyzaijs阅读 983评论 0 3
  • 接触了RN之后,必不可免得要接触界面之间跳转之类的需求,而这一类需求的实现必须要使用到Navigator这个导航器...
    AnonyPer阅读 1,152评论 0 0
  • 大家学习完了一些常用组件的应用及其布局,现在我们来了解一个单页面app才有的导航navigation react-...
    洪都拉斯的春天阅读 1,694评论 0 0
  • NO.1 鸭梨 每个人面临压力的身体反应各异: @达达令:我是天生的悲观者,一直在跟自己的隐形压力做斗争,从前没意...
    高跟鞋战士阅读 357评论 0 0