ReactNative页面跳转Navigator

 原文:ReactNative页面跳转Navigator

ReactNative页面跳转Navigator

Navigator即导航器,通过导航器我们可以实现应用在不同的页面之间进行跳转。 

导航器会建立一个路由栈,用来弹出,推入或者替换路由状态。该路由栈相当于android原生中使用的任务栈。

renderScene

该方法就相当于我们使用的startActivity方法了,我们可以在该方法中设置需要渲染的场景(跳转的页面),该方法接收两个参数(必要参数),route和navigator,其中route就是路由的页面,navigator是一个Navigator对象,因为Navigator对象拥有pop,push,jump等方法,我们需要导航器对象来实现页面的跳转。而路由route需要我们提前进行配置。

我们来看一下renderScene的使用:

renderScene={(route, navigator) => {letComponent = route.component;return}}

通过上面的方法来实现页面的跳转,同时将导航器作为属性进行传递过去。之前说过,route需要进行配置,通过initialRoute方法来对我们的路由进行初始化, 

如下所示:

    initialRoute={{ name: defaultName, component: defaultComponent }}

1

initialRoute是一个对象,我们通过给对象设置名称和对应的组件完成route的初始化,即只要传入需要跳转的组件的名称和组建对象,即可在renderScene中完成页面的跳转。

再回头看renderScene方法,route参数就是我们通过initialRoute初始化的对象,我们通过route.component即可获得我们需要渲染(即跳转到)的对象,然后在return的时候返回这个对象完成页面的跳转。为了防止出现问题,我们加上route.component为空的判断,如果不为空,再进行渲染。

renderScene={(route, navigator) => {           

 let Component = route.component;

if(route.component) {

    return           

 }       

 }}

configureScene

该方法用来设置指定路由对象的配置信息,从而改变场景的动画或者手势。

configureScene={(route) => {

//跳转的动画

return Navigator.SceneConfigs.VerticalDownSwipeJump;

    }

}

例如通过如下的方法我们就可以对我们即将要跳转的界面设置跳转动画。 

Navigator.SceneConfigs为我们提供了大量的跳转动画,具体可以参考如下文件。

MyProject\node_modules\react-native\Libraries\CustomComponents\Navigator\NavigatorSceneConfigs.js

这样我们就完成了在程序默认页面到我们自定义页面之间的跳转过程。

完整代码如下所示:

'use strict';

import React, {  AppRegistry,  Component,  StyleSheet,  Text,  Image,    TextInput,  View,  Navigator} from 'react-native';

import FirstPageComponent  from './app/src/FirstPageComponent';

export defaultclass MyProject extends React.Component {   

     render() {        

            var defaultName ='FirstPageComponent';       

            var defaultComponent = FirstPageComponent;

            return({

                        //跳转的动画

                    returnNavigator.SceneConfigs.FadeAndroid;          

        }}          

        renderScene={(route, navigator) => {            

        let Component = route.component;

        if(route.component){

        return            

}         

 }} /> 

       );   

 }}

 AppRegistry.registerComponent('MyProject', () => MyProject);

其中FirstPageComponent是我们自定义的一个组件,没有添加功能,只放了一个Text,如下所示:

importReact,{    View,    Text,} from'react-native';exportdefaultclass FirstPageComponent extends React.Component{    constructor(props){super(props);this.state = {};    }    render(){return(                            我是默认页面                        );    }}

如果我们现在想要实现一个从FirstPageComponent到另一个页面之间的跳转,那我们需要怎么做呢?

因为我们之前在页面跳转的时候将导航器对象作为属性传递给了我们的FirstPageComponent,那么我们此时就可以获取这个navigator对象,navigator中有很多方法可以供我们调用进行导航。

首先我们给创建一个可点击的区域包裹Text,这样点击Text就可以触发事件,如下所示,改造render,

render() {return(点我跳转);    }

我们先不关注TouchableOpacity是什么,只知道他是一片可点击的区域,并且拥有点击事件即可。

然后我们实现_pressButton方法,如下所示:

_pressButtoon() {

    const { navigator} =this.props;

    if(navigator) {

            navigator.push({

                name:'SecondPageComonent',

                component:SecondPageComonent,

            })

        }

    }

我们从传递过来的属性中获取navigator,然后调用navigator的push方法,push方法接收的参数为route对象,我们定义route对象的名称和组件对象,将其放入路由栈,这样我们通过操控路由栈的方式实现了另一个页面的跳转。

这样我们改造后的FirstPageComponent如下所示:

import React,{    View,    Text,    TouchableOpacity} from 'react-native';

import SecondPageComonent from "./SecondPageComponent";

exportdefaultclass  FirstPageComponent extends React.Component{

    constructor(props){

        super(props);

        this.state = {};

    }

    _pressButtoon(){

        const { navigator} = this.props;

        if(navigator) {

                navigator.push({   

                 name:'SecondPageComonent',

                component:SecondPageComonent,

            })

        }

    }

    render(){

return(点我跳转 ); 

   }}

其中SecondPageComonent是我们定义的另一个组件,实现代码如下所示:

import React,{  View,    Text,    TouchableOpacity,} from 'react-native';

import FirstPageComponent from './FirstPageComponent';

exportdefaultclass  SecondPageComponent extends React.Component{

        constructor(props){

                super(props);

                this.state = {};

    }

    _pressButton(){

        const { navigator } =this.props;

        if(navigator){

            navigator.pop();

        }

    }

    render(){

    return(                                                点我跳转回去                                        );    }}

在SecondPageComponent中,我们通过控制路由栈将页面出栈的方式pop()完成跳转回到第一个页面的功能。

我们发现,页面的跳转都是通过navigator对象的一系列方法通过对路由栈的操控来实现页面之间跳转加载的功能的,我们看一下导航器都有那些方法:

getCurrentRoutes() - 获取当前栈里的路由,也就是push进来,没有pop掉的那些。 

jumpBack() - 跳回之前的路由,当然前提是保留现在的,还可以再跳回来,会给你保留原样。 

jumpForward() - 上一个方法不是调到之前的路由了么,用这个跳回来就好了。 

jumpTo(route) - 跳转到已有的场景并且不卸载。 

push(route) - 跳转到新的场景,并且将场景入栈,你可以稍后跳转过去 

pop() - 跳转回去并且卸载掉当前场景 

replace(route) - 用一个新的路由替换掉当前场景 

replaceAtIndex(route, index) - 替换掉指定序列的路由场景 

replacePrevious(route) - 替换掉之前的场景 

immediatelyResetRouteStack(routeStack) - 用新的路由数组来重置路由栈 

popToRoute(route) - pop到路由指定的场景,其他的场景将会卸载。 

popToTop() - pop到栈中的第一个场景,卸载掉所有的其他场景。

参数的传递

当我们从一个页面跳转到另一个页面的时候,总免不了需要进行参数的传递,那么我们怎么将参数传递到另一个页面呢?

我们可以通过push()方法将参数传递过去。

首先我们需要明确FirstPageComponent,MyProject和SecondPageComponent三者之间的关系,程序启动时首先会启动MyProject,然后看到在MyProject中有一个导航器,该导航器初始化路由的时候获取了我们的FirstPageComponent,将其解析为一个组件在renderScene的时候将其加载到页面上。我们再来看一下导航器加载的方法:

renderScene={(route, navigator) => {

            let Component = route.component;

            if(route.component){

                    return

            }

        }}

我们所有的组件都是通过导航器加载到页面上的,第一个页面是,第二个页面并不是由第一个页面启动的,而是有导航器控制路由栈来显示在页面上的,我们在renderScene是获取到第一个页面,并且将其渲染到屏幕上,我们在第一个页面中设置的push信息也是将信息传递给导航器的,那么我们就可以在这个时候将需要传递给Navigator,然后让其在传递给第二个页面,这样就可以完成参数的传递。

首先我们更改FirstPageComponent的按钮点击事件,如下所示:

navigator.push({

            name:'SecondPageComonent',

            component:SecondPageComonent,

            params:{

                        message:"I am from FirstPageComponent",

            }

        })

然后在Navigator中获取,如下所示:

renderScene={(route, navigator) => {

            let Component = route.component;

            if(route.component){

                    return

            }

        }}


在这里就相当于将参数传递给了Navigator,展开成然后我们就可以在第二个页面中通过props.message获取到信息,如下所示,添加页面挂载时的方法,设置状态的方法将获取到的参数保存在state中:

componentDidMount(){

            this.setState({

            message:this.props.message,

        });

    }

如果当我们返回的时候需要携带参数,我们可以通过给navigator设置一个回调方法,用于给第一个页面设置信息,这样就可以完成返回时数据的传递了。

完整代码如下所示:

index.android.js

'use strict';

import React, {  AppRegistry,  Component,  StyleSheet,  Text,  Image,    TextInput,  View,  Navigator} from'react-native';

import FirstPageComponent from './app/src/FirstPageComponent';

exportdefaultclass MyProject extends React.Component {

    render() {

        var defaultName ='FirstPageComponent';

        var defaultComponent = FirstPageComponent;

        return({

                //跳转的动画

                return  Navigator.SceneConfigs.FadeAndroid;

          }}

          renderScene={(route, navigator) => { 

           let Component = route.component;

            if(route.component){

                    return

            }

          }} />        );

    }}

 AppRegistry.registerComponent('MyProject', () => MyProject);


FirstPageComponent.js

import React, {    View,    Text,    TouchableOpacity} from 'react-native';

import SecondPageComonent from "./SecondPageComponent";

export defaultclass FirstPageComponent extends React.Component{ 

   constructor(props){

        super(props);

        this.state = {

                resultMessage:"hello",

        };

    }

    _pressButtoon(){ 

       var _this =this;

        const{ navigator} =this.props;

        if(navigator) {

            navigator.push({

                name:'SecondPageComonent',

                component:SecondPageComonent,

                params:{ 

                   message:"I am from FirstPageComponent",

                   getResult:function(myMessage){

                        _this.setState({

                            resultMessage:myMessage, 

                       }) 

                   }

                } 

           })

        }

    }

    render(){

            return({this.state.resultMessage}); 

 }}


SecondPageComponent.js

import React,{    View,    Text,    TouchableOpacity,} from 'react-native';

import FirstPageComponent from './FirstPageComponent';

export defaultclass SecondPageComponent extends React.Component{

    constructor(props){

     super(props);

    this.state = {   

            message:"",

        };

    }

    componentDidMount(){

            this.setState({

            message:this.props.message,

        });

    }

    _pressButton(){const{ navigator } =this.props;

    if(this.props.getResult){

        this.props.getResult("This is from SecondPageComponent");

     }

    if(navigator){

            navigator.pop();

        }

    }

    render(){return(

                                                {this.state.message}  

                                      );

    }}

最终效果如下所示: 

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

推荐阅读更多精彩内容