博客
关于我
React Native--FlatList与SectionList
阅读量:560 次
发布时间:2019-03-09

本文共 2189 字,大约阅读时间需要 7 分钟。

React Native 中的 FlatList 和 SectionList 组件比较

React Native 提供了 FlatList 和 SectionList 两个高效的组件,用于渲染一维和二维数据,分别适用于不同场景。理解它们的区别和使用方法可以帮助开发者更高效地构建应用程序。

1. FlatList

FlatList 是 React Native 用于渲染一维数据的核心组件,广泛应用于列表展示。以下是 FlatList 的主要属性和使用方法:

常用属性

  • data:定义 FlatList 的数据来源。数据需要是一个一维数组,每个元素通常包含 key 字段。

  • keyExtractor:定义每个数组元素的键值。React 用于通过键值区分同类元素,提升渲染效率。默认情况下,React 会尝试从数据对象中提取键名。如果没有提供 keyExtractor,默认使用索引值。

  • renderItem:定义每个元素的渲染方式。默认接受 rowData 作为参数,可用于访问数据项。

  • ItemSeparatorComponent:定义单元间的分割组件,用于布局美化。

  • ListHeaderComponent:定义列表头部的渲染组件。

  • ListFooterComponent:定义列表底部的渲染组件。

  • onEndReached:在列表滚动到底部时触发该函数,适用于 lazyloading 的场景。

示例代码

// 示例 FlatList 使用场景class App extends Component {  render() {    return (      
index.toString()} renderItem={this.renderIcon} ListHeaderComponent={this.renderHeader} ListFooterComponent={this.renderFooter} ItemSeparatorComponent={this.renderSeparator} />
); } renderIcon(rowData) { return (
{rowData.item.title}
); }}

调用方法

  • scrollToEnd():滚动至列表底部。

  • scrollToIndex(viewPosition, index):滚动至指定元素的位置,viewPosition 控制阅读位置(0 为顶部,1 为底部)。

2. SectionList

SectionList 与 FlatList 类似,但专门用于渲染二维数据。适用于需要分组展示的场景。

常用属性

  • sections:定义二维数据来源。每个 section 通常包含 dataheader 属性。

  • renderSectionHeader:定义分组头部的渲染方式。

  • renderItem:定义每行数据的渲染方式。

示例代码

// 示例 SectionList 使用场景class App extends Component {  render() {    return (      
index.toString()} renderItem={this.renderCarRow} renderSectionHeader={this.renderCarSection} ListHeaderComponent={this.renderHeader} />
); } renderCarSection(carData) { return (
{carData.section.title}
); } renderCarRow(carData) { return (
{carData.item.name}
); }}

调用方法

  • scrollToLocation(sectionIndex, itemIndex, viewPosition):滚动至指定分组和第几个元素的位置。

注意事项

  • Sections 中的每个数据对象必须包含 keydata 属性,否则 SectionList 将无法正确识别分组。

React Native 提供的 FlatList 和 SectionList 组件为开发者提供了灵活的数据展示选项。根据具体需求选择搭配 Just-in-Time 渲染策略,全能提升应用性能。

转载地址:http://cjfpz.baihongyu.com/

你可能感兴趣的文章
Nginx学习总结(14)——Nginx配置参数详细说明与整理
查看>>
nginx学习笔记002---Nginx代理配置_案例1_实现了对前端代码的方向代理_并且配置了后端api接口的访问地址
查看>>
Nginx安装与常见命令
查看>>
Nginx安装及配置详解
查看>>
nginx安装配置
查看>>
Nginx实战经验分享:从小白到专家的成长历程!
查看>>
Nginx实现反向代理负载均衡
查看>>
nginx实现负载均衡
查看>>
nginx开机启动脚本
查看>>
nginx异常:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf
查看>>
nginx总结及使用Docker创建nginx教程
查看>>
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf/nginx.conf:128
查看>>
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in usrlocalnginxconfnginx.conf128
查看>>
nginx日志分割并定期删除
查看>>
Nginx日志分析系统---ElasticStack(ELK)工作笔记001
查看>>
Nginx映射本地json文件,配置解决浏览器跨域问题,提供前端get请求模拟数据
查看>>
nginx最最最详细教程来了
查看>>
Nginx服务器---正向代理
查看>>
Nginx服务器上安装SSL证书
查看>>
Nginx服务器基本配置
查看>>