1. ListView dataSource

介绍:

ListView需要指定数据的来源。传入数据必须是数组,或者是字典里面嵌套数组

系统会根据你传入的数据自动生成section和row

每一个字典的key会被ListView拆分成一个section(小节,这里的section和原生的一样),如果你不指定sectionId,则key就是sectionId

如何使用。

在构造函数中指定ListView的取值策略,先new一个dataSource对象

constructor(props) {

super(props);

var ds =new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});

}

rowHasChanged 可以是以下几种

1.getRowData(dataBlob, sectionID, rowID):表明我们将以何种方式从dataBlob(数据源)中提取出rowData,sectionID用于指定每一个section的标题名(在renderRow,renderHeader等方法中会默认拆开并作为参数传入)

2.getSectionHeaderData(dataBlob, sectionID):表明我们将以何种方式从dataBlob(数据源)中提取出HeaderData。HeaderData用于给每一个sectionHeader赋值

3.rowHasChanged(prevRowData, nextRowData):指定我们更新row的策略,一般来说都是prevRowData和nextRowData不相等时更新row

4.sectionHeaderHasChanged(prevSectionData, nextSectionData):指定我们更新sectionHeader的策略,一般如果用到sectionData的时候才指定

默认数据的提取策略

{ sectionID_1: { rowID_1: rowData1, ... }, ... }

或者:

==**{ sectionID_1: [ rowData1, rowData2, ... ], ... }**==

或者:

[ [ rowData1, rowData2, ... ], ... ]

作者:sidiWang
链接:https://www.jianshu.com/p/1293bb8ac969
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

大多数情况下我们会用到第二种(字典套数组)和第三种(纯数组),每一个数组对应的key系统会自动提取成sectionId。然后我们可以根据sectionId来判断所加载的section

为dataSource传递数据


cloneWithRows(dataBlob, rowIdentities)

dataBlob是原始数据源。在没有section的时候使用此方法

,传入一个数组。rowIdentities为可选类型,为数据源的每一项指明一个id

。默认的id为字符串'0','1','2'...dataBlob.count

cloneWithRowsAndSections(dataBlob, sectionIdentities, rowIdentities)

字典套数组的结构(有section),我们使用下面的方法为数据源赋值。sectionIdentities和rowIdentities都是可选类型

例子1-最简单的ListView实现。

//1。构造函数中声明
/*第一步我们创建了DataSource对象,提供了row更新的策略。
然后我们在初始化state的时候,初始化一个dataSource和一个data属性
*/
constructor(props) {
super(props);
var ds=new ListView.DataSource({rowHasChanged:(r1,r2)=>r1!=r2})
this.state={
dataSource:ds,
data:["h","h","h","h","h"]
}
}
//行方法
_renderRow(rowData,rowId)
{
return (
<Text>{rowData+''+rowId}</Text>
)
} //listview 的使用。
/*
调用了dataSource对象提供的cloneWithRows方法给ListView的dataSource赋值,
并传入了数据源data。然后在renderRow方法中返回一个Text控件,将每一行的内容和rowId打印出来。
*/
<ListView
dataSource={this.state.dataSource.cloneWithRows(this.state.data)}>
renderRow={(rowData,sectionId,rowId)=>this._renderRow(rowData,rowId)} </ListView>

例子2-实现一个带有section的ListView。

RN会根据你传入的数据源判断是否含有section,并调用cloneWithRowsAndSections把数据源传给ListView。如果你不指定sectionId,则RN会默认按之前提到过的数据结构取出相应的sectionId和rowId

注意,如果使用cloneWithRowsAndSections传入数据源,必须在构造方法里面传入sectionHeaderHasChanged方法

constructor(props) {
super(props);
var ds=new ListView.DataSource({
rowHasChanged:(r1,r2)=>r1!=r2,
sectionHeaderHasChanged:(s1,s2)=>s1!=s2
})
this.state={
dataSource:ds,
data:{a:['h','m'],b:['h1','m1'],c:['h2','m2']}
}
} // section 是a, rowid 是0开头, rowdata是h,m _renderRow(rowData,rowId,sectionId)
{
return (
<Text>{rowData+''+rowId+''+sectionId}</Text>
)
} <ListView
dataSource={this.state.dataSource.cloneWithRowsAndSections(this.state.data)}>
renderRow={(rowData,sectionId,rowId)=>this._renderRow(rowData,rowId,sectionId)}
</ListView>

RN中关于ListView的使用的更多相关文章

  1. 解决在ScrollView中套用ListView显示不正常

    最近在设计Android程序时,因为需要在ScrollView中添加一个ListView列表来显示一些信息.刚开始并没有想太多,但添加进去后才发现ListView不论怎样定义都只能显示一行,显示效果很 ...

  2. ScorllView中嵌套listView与Viewpager的焦点问题处理

    解决进入该页面直接显示中的listview而不是从页面最顶端开始显示在setAdapter后调用listview的smoothScrollTo(0,20); 解决listview只能显示一条 需要重写 ...

  3. “Win10 UAP 开发系列”之 在MVVM模式中控制ListView滚动位置

    这个扩展属性从WP8.1就开始用了,主要是为了解决MVVM模式中无法直接控制ListView滚动位置的问题.比如在VM中刷新了数据,需要将View中的ListView滚动到顶部,ListView只有一 ...

  4. 在Activity中响应ListView内部按钮的点击事件

    最近交流群里面有人问到一个问题:如何在Activity中响应ListView内部按钮的点击事件,不要在Adapter中响应? 对于这个问题,我最初给他的解答是,在Adapter中定义一个回调接口,在A ...

  5. Xamarin.Forms中的ListView的ItemTrapped事件与ItemSelected事件的区别

    今天对Xamarin.Forms中的ListView的两个事件(ItemTrapped和ItemSelected)做了小小的研究,发现有以下几点区别: 1.ItemTrapped事件会优先被触发. 2 ...

  6. C#中使用ListView动态添加数据不闪烁并显示当前插入值

    首先,自定义一个类ListViewNF,继承自 System.Windows.Forms.ListView class ListViewNF : System.Windows.Forms.ListVi ...

  7. 实现ScrollView中包含ListView,动态设置ListView的高度

    ScrollView 中包含 ListView 的问题 : ScrollView和ListView会冲突,会导致ListView显示不全 <?xml version="1.0" ...

  8. 关于ScrollView中嵌套listview焦点滑动问题 解决

    (第三种,第四种简单推荐使用) 在这里我要提出的是,listview能滚动的前提是:当listview本身的高度小于listview里的子view. 第一种方法 只需在MainActivity中 找到 ...

  9. Activity中与ListActivity中使用listview区别

    Activity中与ListActivity中使用listview区别 一.Activity中与ListActivity中使用listview区别(本身没多大区别,只是ListActivity在lis ...

随机推荐

  1. 第4章 NumPy基础

    NumPy是高性能科学计算和数据分析的基础包. 主要功能: 1.ndarray,一个具有矢量算术运算和复杂广播能力的快速且节省空间的多维数组. 2.用于对整组数据进行快速运算的标准数学函数(无需编写循 ...

  2. JavaScript之图片操作3

    在页面布局中,常常会用到九宫格布局,如下图所示: 本次我们就以九宫格为基础进行图片的布局操作,首先我们以上面的图片的为例,假设每个格子的大小都相同,将每一个格子相对其父元素进行定位,这样,我们只需要控 ...

  3. SpringAOP基础 - 静态代理设计模式

    代理模式在实现过程中,要创建一个接口(社交技巧-接口),代理类(经纪人 - 类)和真实类(范冰冰 - 类)同时实现这个接口. 举个例子: 我们想要找范冰冰吃饭,但是呢,她是大明星,不可能轻易见我们,我 ...

  4. 学习笔记之Microsoft Azure

    Microsoft Azure - Wikipedia https://en.wikipedia.org/wiki/Microsoft_Azure Microsoft Azure (formerly  ...

  5. [UE4]角色、动画蓝图、动画蒙太奇、动画之间的调用关系

    一.在“角色”中设置要使用的“动画蓝图” 二.在“动画蓝图”中使用“动画”和“混合动画” 三.在“混合动画”中,也可以使用“动画” 四.在角色中使用“动画蒙太奇”

  6. ECCV 2018 | UBC&腾讯AI Lab提出首个模块化GAN架构,搞定任意图像PS组合

    通常的图像转换模型(如 StarGAN.CycleGAN.IcGAN)无法实现同时训练,不同的转换配对也不能组合.在本文中,英属哥伦比亚大学(UBC)与腾讯 AI Lab 共同提出了一种新型的模块化多 ...

  7. 关于Node和Deno

    Node和Deno的作者Ryan Dahl开Deno并不是“just for fun”, 也不是为了取代Node, 他有着更加远大的目标. 记住以下要点: 1. Deno目前只是一个Demo或者说是原 ...

  8. Python - Django - ORM 实例(二)

    在 app01/models.py 中添加 Book 类对象表 from django.db import models # Create your models here. # 出版社 class ...

  9. Hadoop使用场景

    Hadoop使用场景: 大数据量存储:分布式存储 日志处理: Hadoop擅长这个 海量计算: 并行计算 ETL:数据抽取到oracle.mysql.DB2.mongdb及主流数据库 使用HBase做 ...

  10. C# 方法中带默认值的参数

    设计一个方法的参数时,可为部分或全部参数分配默认值.然后,调用这些方法的代码可以选择不指定部分实参,接受其默认值.除此之外,调用方法时,还可通过指定参数名称的方式为其传递实参.以下代码演示了可选参数和 ...