《React Native移动开发实战》一一3.6 添加页面跳转功能——Navigator组件

简介: 本节书摘来自华章出版社《React Native移动开发实战》一 书中的第3章,第3.6节,作者:袁林 著 ,更多章节内容可以访问云栖社区“华章计算机”公众号查看。

3.6 添加页面跳转功能——Navigator组件
React Native实现页面跳转的组件有Navigator以及NavigatorIOS,和前面介绍过的ViewPagerAndroid问题一样,为了考虑平台兼容性和代码复用性,这里使用同时支持iOS和Android的Navigator组件。
在正式使用Navigator之前,首先需要对现有的ch04项目做一些简单的重构:将首页的实现移植到新建的home.js文件中,以便后面的逻辑改动。
(1)新建home.js文件,将app.js的内容全部复制至home.js文件中。同时,不要忘记修改home.js文件中组件的名称。修改home.js代码如下:

01 export default class home extends Component { // 将组件名称从"app"修改成"home"

(2)修改app.js文件的代码如下:

01 import React, {Component} from 'react';
02 import {View, Navigator} from 'react-native';
03
04 import Home from './home';
05
06 export default class app extends React.Component {
07 render() {
08 return (
09 10 initialRoute={{
11 name: 'home',
12 component: Home
13 }}
14 configureScene={(route) => {
15 return Navigator.SceneConfigs.FloatFromRight;
16 }}
17 renderScene={(route, navigator) => {
18 const Component = route.component;
19 return
20 }}/>
21 );
22 }
23 }

重新加载应用,保证运行效果和重构前完全一致,如图3.26所示。
image

图3.26 代码重构后的运行效果
对于上述代码,读者可能会有很多疑惑,这里来一一说明。
Navigator组件的initialRoute属性定义了应用启动时加载的路由(route),而路由是Navigator组件用来识别渲染场景的一个对象,简单来说,initialRoute中定义的组件就是应用第一个要显示的页面,这就是首页home.js。
Navigator组件的configureScene属性定义了页面之间跳转的动画,除了代码中的Navigator.SceneConfigs.FloatFromRight;外,还有很多React Native已经为我们定义好的动画,包括:
? FloatFromRight;
? FloatFromLeft;
? FloatFromBottom;
? FloatFromBottomAndroid;
? FadeAndroid;
? HorizontalSwipeJump;
? HorizontalSwipeJumpFromRight;
? VerticalUpSwipeJump;
? VerticalDownSwipeJump。
?提示:动画效果也考虑到了平台差异性,这点可以从动画命名可以看出,例如只支持Android的动画有FloatFromBottomAndroid以及FadeAndroid等。
?注意:由于动画效果暂时无法在书中呈现给读者,所以读者感兴趣的话,可以自己动手运行应用体验不同的动画效果。
Navigator组件的renderScene()函数应该是最容易令人困惑的地方了,为此,可以使用React Native调试来一看究竟。在该函数中添加断点并重新运行应用,效果如图3.27所示。
image

图3.27 使用调试断点来查看renderScene运行机制
这里需要重点关注的是右侧调试区域的变量值,如图3.28所示。
image

图3.28 renderScene参数的值
从图3.28中的name可以看出,此时的route里的name和component就是在initialRoute属性中传递的home和home组件,所以app.js文件中这行代码:

01 return

的作用就是返回home组件。当然,这里不仅返回了home组件,还将路由(route)的参数以及navigator参数也传递给了home组件:通过{...route.params}以及navigator= {navigator},于是,在home组件中就可以使用this.props.navigator来获取navigator。

相关文章
|
开发框架 Dart 前端开发
【Flutter前端技术开发专栏】Flutter与React Native的对比与选择
【4月更文挑战第30天】对比 Flutter(Dart,强类型,Google支持,快速热重载,高性能渲染)与 React Native(JavaScript,庞大生态,热重载,依赖原生渲染),文章讨论了开发语言、生态系统、性能、开发体验、学习曲线、社区支持及项目选择因素。两者各有优势,选择取决于项目需求、团队技能和长期维护考虑。参考文献包括官方文档和性能比较文章。
747 0
【Flutter前端技术开发专栏】Flutter与React Native的对比与选择
|
移动开发 前端开发 JavaScript
React DnD:实现拖拽功能的终极方案?
本文首发于微信公众号“前端徐徐”,介绍了一个强大的 React 拖拽库——React DnD。React DnD 帮助开发者轻松创建复杂的拖拽界面,适用于 Trello 风格的应用、列表重排序、可拖拽的 UI 组件等场景。文章详细介绍了 React DnD 的基本信息、主要特点、使用场景及快速上手指南。
1415 3
React DnD:实现拖拽功能的终极方案?
|
移动开发 前端开发
react项目配合diff实现文件对比差异功能
在React项目中,可以使用`diff`库实现文件内容对比差异功能。首先安装`diff`库,然后在组件中引入并使用`Diff.diffChars`或`Diff.diffLines`方法比较文本差异。通过循环遍历`diff`结果,可以生成不同样式的HTML元素来高亮显示文本差异。
766 1
react项目配合diff实现文件对比差异功能
|
前端开发
React 中购物车功能实现(全选多选功能实现)
React 中购物车功能实现(全选多选功能实现)
179 2
|
前端开发
|
存储 JavaScript 前端开发
探索React状态管理:Redux的严格与功能、MobX的简洁与直观、Context API的原生与易用——详细对比及应用案例分析
【8月更文挑战第31天】在React开发中,状态管理对于构建大型应用至关重要。本文将探讨三种主流状态管理方案:Redux、MobX和Context API。Redux采用单一存储模型,提供预测性状态更新;MobX利用装饰器语法,使状态修改更直观;Context API则允许跨组件状态共享,无需第三方库。每种方案各具特色,适用于不同场景,选择合适的工具能让React应用更加高效有序。
339 0
|
Dart 前端开发 JavaScript
探索移动应用开发中的跨平台解决方案:Flutter与React Native的比较
在移动应用开发领域,选择合适的跨平台解决方案是关键。本文将深入分析Flutter和React Native这两大主流框架,从性能、开发效率、社区支持等方面进行比较,帮助开发者做出明智的选择。
414 27
|
存储 移动开发 前端开发
初探react,用react实现一个todoList功能
该文章通过创建一个TodoList应用来介绍React的基础知识,包括环境搭建、组件创建、状态管理和事件处理,并演示了如何使用React Hooks来优化组件逻辑。
|
前端开发 JavaScript Android开发
React Native跨平台开发实战
【7月更文挑战第21天】React Native为跨平台移动应用开发提供了一种高效且强大的解决方案。通过本文的学习,你应该能够掌握React Native的基本概念和实战步骤,并开始在你的项目中使用React Native进行开发。随着你对React Native的深入理解,你将能够利用其强大的功能来构建更加复杂和高效的移动应用。
|
开发框架 移动开发 前端开发
【Uniapp 专栏】Uniapp 与 React Native 的对比分析
【5月更文挑战第14天】Uniapp和React Native是热门的跨平台移动开发框架。Uniapp以其一套代码多端运行、丰富的组件生态和较低的学习曲线受到青睐,适合快速开发简单应用。React Native基于React,拥有活跃社区和优秀性能,适合复杂应用。React Native在性能上略胜一筹,尤其在需要接近原生体验的场景。Uniapp的官方组件弥补了社区资源不足。选择时需考虑开发效率、性能需求、团队技术栈和社区支持。
3227 1
【Uniapp 专栏】Uniapp 与 React Native 的对比分析