美文网首页程序员
react-native实现页面跳转createStackNav

react-native实现页面跳转createStackNav

作者: 吴敬悦 | 来源:发表于2018-11-16 21:29 被阅读380次

    此篇教程会持续更新。。。

    官方文档createStackNavigator

    调试环境

    为了能够让阅读者容易上手,我先将简单的代码附上,阅读者拷贝到自己的代码看看效果,然后再看我的教程一点点深入了解createStackNavigator,达到灵活运用。

    演示步骤

    1)首先使用终端切换到项目所在目录下,输入:npm install --save react-navigation,等待安装成功,一般学习到这里自己的电脑上肯定已经安装好了npm,这个在安装node的时候会默认安装;

    2)下面这个是配置路由的页面,你将这个页面放在单独的组件中,这个组件不能含有其他组件,我取名叫Main.js:

    import {createStackNavigator} from 'react-navigation';

    import Test01 from './Test01';

    import Test02 from './Test02';

    const App = createStackNavigator({

        Test01:{

            screen:Test01,

            navigationOptions:({navigation})=>({

                title:'这是Test01的标题'

            })

        },

        Test02:{

            screen:Test02,

            navigationOptions:({navigation})=>({

                title:'这是Test02的标题'

            })

        }

    },{

        initialRouteName:'Test01'

    });

    module.exports = App;

    记住导入的那两个文件必须与这个文件在同一目录,如果不在需要自己修改上面的路径(假如,你还不知道怎么导入的话,一般学到这里都了解了,你就按照我的要求放在同一个文件夹中,同时希望你能去看相关的教程来提高自己);

    3)新建文件名称为:Test01.js:

    import React,{Component} from 'react';

    import {Button} from 'react-native';

    export default class Test01 extends Component{

        render(){

            return (

                <Button onPress={()=>this.props.navigation.navigate('Test02')} title={'跳转到test02页面'} />

            );

        }

    }

    4)新建文件名称:Test02.js:

    import React,{Component} from 'react';

    import {Text} from 'react-native';

    export default class Test01 extends Component{

        render(){

            return (

                <Text>这是test02页面</Text>

            );

        }

    }

    这样就完成工作了,接下来看看效果:

    刚进来的页面

    当我点击按钮“跳转到test02页面”以后,会跳转到下面这个页面:

    跳转以后的页面

    这样就实现了页面跳转。下面就说说代码里面的东西,对应效果。

    细节说明

    1)在Main.js代码中,像import {createStackNavigator} from 'react-navigation';这行代码是导入createStackNavigator,而这个是属于react-navigation库中的,这个库中还封装了标签导航(也就是qq、微信下面的那种),抽屉导航(qq右滑的那个效果),这些我都会在以后的博客中更新;

    2)import Test01 from './Test01';import Test02 from './Test02';这个是包含需要跳转的页面,我这里有两个页面,一个是Test01,另一个是Test02;

    3)createStackNavigator函数,这个就是设置栈式导航路由的,函数原型:createStackNavigator(RouteConfigs, StackNavigatorConfig);这个函数有两个参数,第一个是路由配置,是一个对象,里面的键值对就是一个个路由,就是需要跳转的页面,其中键的值是路由名称,也就是页面的名称,这个名称可以跟创建的类名不同(我只是习惯弄成一样的),想想在js中的类,其中键的值可以自己随便取;值的值是一个对象,

    对象里面第一个属性是screen,这个的值必须与上面导入的值相同;

    第二个参数是path,这个我一直没用到过;

    第三个参数是navigationOptions,这个属性主要是设置导航栏的,比如说导航栏的背景颜色,返回按钮等等,具体的参数官网都有介绍,可返回到上面点击链接跳转到官网进行查看,我说几个常见的属性,一般导航栏的标题需要设置,使用title,这个属性接受一个字符串;header,使用这个属性主要是当我们不需要导航栏的时候,这个时候需要将其设置为null,形如:header:null;headerBackImage这个属性是自定义返回按钮的图片,这个属性在安卓与苹果上默认效果不同,一般都要自定义,这个属性接受一个像<Image/>这样的组件,官方提供一个回调函数,只要最后返回值是像<View>这样的就行,回调函数参数是一个对象,常用的属性是tintColor,这个属性你用了就知道什么意思了,我不知道怎么描述,官方解释的是:Color of the currently selected tab icon,反正我像下面设置以后就变成了浅蓝色:<Image source={require('../res/left.png')} style={{width:30,height:30,tintColor:tintColor}} />;headerBackTitle这个属性是返回文本,接受一个字符串或者null,当是null的时候没有返回文本;

    4)createStackNavigator函数的第二个参数StackNavigatorConfig,这个我在使用中一般只使用initialRouteName这个属性,这个属性的意思就是默认路由,也就是刚进去的时候显示的是哪一个页面,一般不设置这个属性的话,默认是第一参数的第一个路由作为第一个页面,否则按照这儿设置的;

    5)把createStackNavigator函数设置完成以后,将这个函数的返回值导出,使用module.exports这种方式导出和使用export default的方式导出都没有问题;

    6)在需要跳转的地方,书写代码this.props.navigation.navigate("这里填设置时写的路由名称,也就是键的值")(就像Test01这个页面里面按钮触发事件一样),而无需再一次导入createStackNavigator,在被设置到栈式导航里面的所有页面,里面都有一个静态的navigationOptions对象,跟设置createStackNavigator函数的第一个参数里面的navigationOptions是一样的,也就是说,你可以将这个参数写到每一个页面里面,也可以写在配置路由的地方,在页面中具体怎么写,我把代码写到Test01.js里面,看下面;

    import React,{Component} from 'react';

    import {Button} from 'react-native';

    export default class Test01 extends Component{

        static navigationOptions = {

            title:'这是第一个页面'

        }

        render(){

            return (

                <Button onPress={()=>this.props.navigation.navigate('Test02')} title={'跳转到test02页面'} />

            );

        }

    }

    一般我们使用栈式导航createStackNavigator主要是为了实现页面跳转,如果我们再将常用navigationOptions放到每一个页面里面,那么可以说createStackNavigator里面就只有配置路由名称这个工作,但这个工作我们却需要写上面那么多对象,显然是不好的,官方也考虑到了,配置路由的简写形式:

    createStackNavigator({

        Test01:Test01,

        Test02:Test02

    },{

        initialRouteName:'Test01'

    });

    这样就搞定了,是不是很简单,如果你想深入了解栈式导航,那么需要阅读react-navigation生命周期和react-native实现页面跳转createStackNavigator(精华篇)(以后更新),一般入门篇的知识就已经能够满足我们大部分开发。

    相关文章

      网友评论

        本文标题:react-native实现页面跳转createStackNav

        本文链接:https://www.haomeiwen.com/subject/mijvfqtx.html