《React Native移动开发实战》一一3.8 实现页面间的数据传递

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

3.8 实现页面间的数据传递
跳转和返回的效果实现了,那么,如何实现页面间的数据传递和通信呢?
其实,从上述代码中读者已经可以发现:React Native使用props来实现页面间数据传递和通信。在React Native中,有两种方式可以存储和传递数据,即props(属性)以及state(状态),其中:
? props通常是在父组件中指定的,而且一经指定,在被指定的组件的生命周期中则不再改变。
? state通常是用于存储需要改变的数据,并且当state数据发生更新时,React Native会刷新界面。
了解了props与state的区别之后,读者应该知道,要将首页的数据传递到下一个页面,需要使用props。所以修改home.js代码如下:

01    export default class home extends React.Component {
02         // 这里省略了没有修改的代码
03 
04        _renderRow = (rowData, sectionID, rowID) => {
05            return (
06                <TouchableHighlight onPress={() => {
07                    const {navigator} = this.props; // 从props获取navigator
08                    if (navigator) {
09                        navigator.push({
10                            name: 'detail',
11                            component: Detail,
12                            params: {
13                                productTitle: rowData.title
                                                     // 通过params传递props
14                            }
15                        });
16                    }
17                }}>
18                    // 这里省略了没有修改的代码
19                </TouchableHighlight>
20            );
21        }
22    }
AI 代码解读

在home.js中,为Navigator的push()方法添加的参数params,会当做props传递到下一个页面,因此,在detail.js中可以使用this.props.productTitle来获得首页传递的数据。修改detail.js代码如下:

01    export default class detail extends React.Component {
02        render() {
03            return (
04                <View style={styles.container}>
05                    <TouchableOpacity onPress={this._pressBackButton.bind
                     (this)}>
06                        <Text style={styles.back}>返回</Text>
07                    </TouchableOpacity>
08                    <Text style={styles.text}> 
09                        {this.props.productTitle}
10                    </Text>
11                </View>
12            );
13        }
14 
15        // 这里省略了没有修改的代码
16    }
AI 代码解读

重新加载应用,当再次单击商品列表时,详情页面将显示单击的商品名称,效果如图3.31所示。
image

图3.31 详情页面显示单击的商品名称
这样,一个完整的页面跳转和页面间数据传递的功能就实现了。

目录
打赏
0
0
0
0
1408
分享
相关文章
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
442 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
除了使用Route组件,React Router还有其他方式处理404错误页面吗
除了使用Route组件,React Router还有其他方式处理404错误页面吗
81 58
如何在React Router中定义404错误页面组件?
如何在React Router中定义404错误页面组件?
76 57
在React Router中,如何处理路由的404错误页面?
在React Router中,如何处理路由的404错误页面?
84 57
SpringBoot + 通义千问 + 自定义React组件:支持EventStream数据解析的技术实践
【10月更文挑战第7天】在现代Web开发中,集成多种技术栈以实现复杂的功能需求已成为常态。本文将详细介绍如何使用SpringBoot作为后端框架,结合阿里巴巴的通义千问(一个强大的自然语言处理服务),并通过自定义React组件来支持服务器发送事件(SSE, Server-Sent Events)的EventStream数据解析。这一组合不仅能够实现高效的实时通信,还能利用AI技术提升用户体验。
462 2
React 数据表格分页实现
本文详细介绍了如何在React中实现数据表格的分页功能,包括基础实现、常见问题及解决方案。通过状态管理和事件处理,我们可以有效地减少页面加载时间,提升用户体验。文章提供了完整的代码示例,帮助开发者解决分页按钮样式、按钮过多和初始加载慢等问题,并给出了相应的优化方案。
147 53
React 数据表格排序与过滤
本文介绍了如何在 React 中实现数据表格的排序和过滤功能,从基础概念到实际代码实现,涵盖排序和过滤的基本原理、实现步骤、常见问题及解决方法。通过合理管理状态、优化性能和避免常见错误,帮助开发者提高用户体验和开发效率。
98 4
react或者vue更改用户所属组,将页面所有数据进行替换(解决问题思路)____一个按钮使得页面所有接口重新请求
在React或Vue中,若需在更改用户所属组后更新页面所有数据但不刷新整个页面,可以通过改变路由出口的key值来实现。在用户切换组成功后,更新key值,这会触发React或Vue重新渲染路由出口下的所有组件,从而请求新的数据。这种方法避免了使用`window.location.reload()`导致的页面闪烁,提供了更流畅的用户体验。
81 1
react或者vue更改用户所属组,将页面所有数据进行替换(解决问题思路)____一个按钮使得页面所有接口重新请求
|
6月前
|
React页面跳转取消上一个页面的所有请求
React页面跳转时取消上一个页面的所有axios请求,通过axios拦截器设置cancelToken,并在页面跳转时调用cancel函数取消未完成的请求。
123 2
React配合axios请求拦截校验session,403跳转至登陆页面
React中使用axios进行请求拦截,通过自定义事件监听和响应拦截实现403状态码时的自动登录页面跳转。
199 2