[教程]   ListView的使用和封装——实战React Native中级案例01

本文介绍如何在React Native中封装和使用ListView,通过一个实战案例展示如何创建一个可响应数据变化的列表。文章讲解了dataSource的处理、数据刷新机制以及如何创建子元件并传递props值,提供了一个实现动态加载和更新的ListView组件。
摘要由CSDN通过智能技术生成

前言

在开发过程中最常见的任务就是建立一个列表,无论是联系人列表或是商品目录等等。为了提高开发效率,这里我们将对ListView进行整理和封装,使得其使用变得方便快捷。

为了检验组件的可用性,我们将开发下图的示例。该程序包含一个列表,可在程序初始化后现实一个数组中的数据。在点击Add Item按键后,列表将会添加新的项目。

这里要注意的是,ListView的部分应进行适当的封装,使得同样的组建可以快速的用于联系人列表或购物清单等场景。

这里写图片描述

想象驱动开发 (Wish-driven Development)

和测试驱动开发类似,想象驱动开发指的是先想象你的代码开发完成后应该如何使用,然后再进行开发,直到代码能够实现你描述的功能。

我想只需要写X我的代码就能做到Y => 一直修改代码直至实现你的愿望

在这个例子中我们希望ListView可以这样使用:

// 代码仅用于展示概念,放到程序里运行不了不要找我
<MyListView data={
    this.state.data} row={<Row />} />

为了实现代码的高重用性,我们希望列表中的每一行的外观都由组建<Row />决定,方便随时调整,然后作为一个props传到组件中,同时我们还不希望对于数据进行管理,而仅仅传入一个数组,ListView就可以自动将数据分发给每个<Row />组件。而数组发生变更的时候,MyListView也应该自动更新。

处理dataSource和数据刷新

ListView的数据来自于dataSource,这个参数必须是一个ListView.DataSource对象。所以我们采用了这样的方法定义dataSource:
首先,定义一个MyListView类用来封装ListView:

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值