接上文,剩下的展示工作是重中之重,首先确定节点的布局草稿——也就是如何render item:

在此之前还有一个重要的问题就是选择何种组件盛放展示子结点,一般有如下两种:

  1. 使用scrollview加载
  2. 使用FlatList/ListView加载

综合考虑之后,选择使用2模拟多级列表——即根据当前的层级(lelve)来确定节点的间距(paddingLeft)。

因此,展示的render函数如下:

 <FlatList
data={this.viewData.data}
keyExtractor={(item, index) => index}
renderItem={this._renderItem}
extraData={this.state}
ItemSeparatorComponent={this._separator}/>

注意上面的extraData={this.state},这是用来强制刷新FlatList,因为FLatList是继承自PureComponent,数据源不改变,那么item的状态不会改变,详情可以参考文档。

确定展示模型之后,着重要做的就是如何进行renderItem了,依据上面途中的规划,节点的布局很简单,在此不赘述。这里需要重点指出的就是如何确立item的属性:即从数据源data中的item如何转换成我们需要的item。本质上也就是为了如何使得组件更加通用,而不是仅仅限于项目使用。试想一下,一个基本的树节点需要有哪些属性,然后根据实际需求,需要添加/转换哪些属性:

首先子结点基本属性有要展示的文本text,展开关闭的状态open,是否选中的状态checked,以及子结点列表_sub_:

根据实际情况需要腹肌的属性,比如当前的所在的层级level,当前的主键key,父节点主键parentKey等。

确定以上item模型之后,我们就可以在构造函数中进行转换props中传来的data了:

    constructor(props) {
super(props); this.state = { }; this.viewData = this._initViewData(this.props.data, [...this.props.selectedItems] || []);
}

  

然后就是递归遍历所有的item,按照上图中规定的属性进行转换:

data.forEach((item, index) => {

            let key = this.props.onGetItemKey(item);
let checked = checkedItemKeys.includes(key); let newItem = this._createNewItem(level, index, checked, item, key, parentKey);
newItem._sub_ = this._getSub(item, level + 1, key, checkedItemKeys); newData.push(newItem);
});

  

_getSub通过this.props.onGetSubList(item)用来递归子结点生成_createNewItem,组装成新的数组。

这一部分完成后,剩下的工作就是处理事件了,比如选中状态的变化,需要递归改变子结点的状态,以及改变兄弟节点和父节点的状态(子结点全选以后父节点自动选中以及子结点取消选中一项以后,父节点需要变成取消的状态。),然后调用this.props.onItemSelect通知主界面。

最后,我们就可以愉快的展示数据了,伪代码如下:

 

 <TreeView ref={(treeView) => this.treeView = treeView}
data={this.viewData.JyFwData}
onGetItemDisplayText={(item) => {
return item.text;
}}
onItemSelect={(checked, item) => {
if (checked) {
this.viewData.result.push(item);
} else {
let index = this.viewData.result.findIndex(value => value.id== item.id);
if (index < 0) {
return;
} this.viewData.result.splice(index, 1);
}
}}
selectedItems={this.viewData.result}
onGetItemKey={(item) => item.key}
onGetSubList={(item) => item.subList}/>

  

React Native中树 TreeView 实现(2)的更多相关文章

  1. React Native中树 TreeView 实现(1)

    背景: 基于项目需要,在搜索第三方类库后没有很好的效果后决定动手实现. 开发环境: React Native 0.44 模型: 由于数据已经全部取出,不需要分级异步加载,故而只需要实现层级展示即可. ...

  2. 在 React Native 中使用 Redux 架构

    前言 Redux 架构是 Flux 架构的一个变形,相对于 Flux,Redux 的复杂性相对较低,而且最为巧妙的是 React 应用可以看成由一个根组件连接着许多大大小小的组件的应用,Redux 也 ...

  3. React Native 中 CSS 的使用

    首先声明,此文原作者为黎 跃春 React Native中CSS 内联样式 对象样式 使用Stylesheet.Create 样式拼接 导出样式对象 下面的代码是index.ios.js中的代码: / ...

  4. react native中的欢迎页(解决首加载白屏)

    参照网页: http://blog.csdn.net/fengyuzhengfan/article/details/52712829 首先是在原生中写一些方法,然后通过react native中js去 ...

  5. React Native中的网络请求fetch和简单封装

    React Native中的网络请求fetch使用方法最为简单,但却可以实现大多数的网络请求,需要了解更多的可以访问: https://segmentfault.com/a/1190000003810 ...

  6. [转] 「指尖上的魔法」 - 谈谈 React Native 中的手势

    http://gold.xitu.io/entry/55fa202960b28497519db23f React-Native是一款由Facebook开发并开源的框架,主要卖点是使用JavaScrip ...

  7. [转] 在React Native中使用ART

    http://bbs.reactnative.cn/topic/306/%E5%9C%A8react-native%E4%B8%AD%E4%BD%BF%E7%94%A8art 前半个月捣腾了一下Rea ...

  8. react native中使用echarts

    开发平台:mac pro node版本:v8.11.2 npm版本:6.4.1 react-native版本:0.57.8 native-echarts版本:^0.5.0 目标平台:android端收 ...

  9. react native中一次错误排查 Error:Error: Duplicate resources

    最近一直在使用react native中,遇到了很多的坑,同时也学习到了一些移动端的开发经验. 今天在做一个打包的测试时,遇到了一个问题,打包过程中报错“Error:Error: Duplicate ...

随机推荐

  1. MySQL数据库的“十宗罪”【转】

    今天就给大家列举 MySQL 数据库中最经典的十大错误案例,并附有处理问题的解决思路和方法.希望能给刚入行或数据库爱好者一些帮助,今后再遇到任何报错,我们都可以很淡定地去处理.学习任何一门技术的同时, ...

  2. 运维小知识之nginx---nginx配置Jboss集群负载均衡

      codyl 2016-01-26 00:53:00 浏览385 评论0 负载均衡 转自 运维小知识之nginx---nginx配置Jboss集群负载均衡-博客-云栖社区-阿里云https://yq ...

  3. pip安装模块时:error: command 'gcc' failed with exit status 1

    用安装python模块出现error: command 'gcc' failed with exit status 1 问题: gcc编译缺少模块 解决方法: yum install gcc libf ...

  4. mac pro上安装docker

    1.进入一下地址进行下载docker https://download.docker.com/mac/stable/Docker.dmg 进入后进行下载后进行安装 2.将其拖动到Appliaction ...

  5. 使用coding云作为git远程库

    1.在命令行中创建GIT仓库 mkdir DriveAssistant cd DriveAssistant git init echo "# DriveAssistant" > ...

  6. python discover 函数介绍

    discover(start_dir,pattern='test*.py',top_level_dir=None)找到指定目录下所有测试模块,并可递归查到子目录下的测试木块,只有匹配到的文件名才会被加 ...

  7. 如何关闭WordPress后台的主题、插件、版本更新通知?

    由于WordPress 更新速度非常快,不论是主题 插件或是版本,每个月少说要执行个好几次,因为更新快,所以WordPress后台加入了更新通知,提醒使用者有新版本了,可以进行插件.主题或是系统更新, ...

  8. 用户代码未处理EntityCommandExecutionmException报错解决方案

    原因可能是(1)没有编译好,清理解决方案,重新生成解决方案.          (2)可能是WebSiteConfiguration.DbProviderName;中为DbProviderName属性 ...

  9. day4正则表达式

    语法: 正则表达式是处理字符串的函数,我们在Excel函数中也有很多这样的公式,因为学过一些Excel,所以看一下有什么不同的方法. import re       #导入re模块,处理正则表达式的模 ...

  10. Python 中for...esle和while...else语法

    Python的for...else和while...else语法,这是Python中最不常用,最为误解的语法特性之一. Python中的for.while循环都有一个可选的else分支(类似if语句和 ...