ListView简单使用《二》—CollectionView效果实现案例

2024-02-29 02:18

本文主要是介绍ListView简单使用《二》—CollectionView效果实现案例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

此案例是在ListView基础上进行的进一步深化使用,步骤与ListView一致,首先还是设置ListView的DataSource,注意事项与前一篇 ListView的简单使用《一》—>普通图文展示案例 一致,直接上代码:

getInitialState(){var dss = new ListView.DataSource({rowHasChanged:(r1,r2)=> r1 !== r2});return {dataSource:dss.cloneWithRows(ImgDatas.data)}
},



向界面添加展示数据的ListView,此处为达到CollectionView的效果,最重要的是对ListView的 contentContainerStyle 进行设置,即对ListView里面的内容进行设置。

render() {return (<View style={styles.container}><ListViewdataSource={this.state.dataSource}renderRow={this.renderRow}contentContainerStyle={styles.listViewStyle}/></View>);
},

添加每行显示的控件,并进行可点击设置,并进行返回,renderRow方法中的四个参数依次为,每行的数据、行ID,组ID,以及高亮显示的行,可省略不写,也可根据自己的需求,进行相应的添加。

 renderRow(rowData,rowID,sectionID,highlightRow){return(<TouchableOpacity activeOpacity={0.5} onPress={this.cellTouched}><View style={styles.cellContentViewStyle}><Image style={styles.cellImageStyle} source={{uri:rowData.icon}}/><Text>{rowData.title}</Text></View></TouchableOpacity>);
},


每行的点击事件,点击之后需要做什么都在这个方法中实现

cellTouched(){
},


在该案列中,最主要的是对界面布局的CSS样式的设置,设置如下:

const styles = StyleSheet.create({container: {flex: 1,},listViewStyle:{
flexDirection:'row',
// //多行显示
flexWrap: "wrap",
alignItems: 'flex-start',
},
cellContentViewStyle:{
width:cellWH,
height:cellWH,
marginLeft:Hmargin,
marginTop:Vmargin,
alignItems:'center'
},
cellImageStyle:{
width:80,
height:80,
marginBottom:5,
},
}); 


需要特别注意的是:
1.我们设置collectionView效果时,主要是对ListView的content进行设置,设置为多个行显示在一排上,而不是单独一行就占一排的位置, 因此需要设置flexDirection为横向显示,值为row。
2.当显示为横排之后,就不会出现一行占一排的情况,但当我们直接设置flexWrap为换行显示即值为wrap,我们并没有看到其他对应的控件展示,然而ListView却占了相应的空间和大小,点击其他区域的时候,响应事件的是第一排显示的几个,其实并不是没有显示出来,只是显示到屏幕之外去了,我们需要设置每排都从左侧位置开始,即可看见所有元素,即设置alignItems为侧轴起始边界开始:如下:
alignItems: 'flex-start'


本案例中用到的几个比较重要的属性:

1.获取屏幕宽度

var Dimensions = require('Dimensions');
var windowWidth = Dimensions.get('window').width;

2.设置每行显示个数

var cols = 3;


3.设置每个cell的宽度

var cellWH = 100;


4.计算cell中间距离

var Hmargin = (windowWidth - cellWH * cols) / (cols + 1);


5.ListView设置上边距

var Vmargin = 25;



效果图如下:












这篇关于ListView简单使用《二》—CollectionView效果实现案例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/757292

相关文章

Spring IOC的三种实现方式详解

《SpringIOC的三种实现方式详解》:本文主要介绍SpringIOC的三种实现方式,在Spring框架中,IOC通过依赖注入来实现,而依赖注入主要有三种实现方式,构造器注入、Setter注入... 目录1. 构造器注入(Cons编程tructor Injection)2. Setter注入(Setter

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

Spring IOC控制反转的实现解析

《SpringIOC控制反转的实现解析》:本文主要介绍SpringIOC控制反转的实现,IOC是Spring的核心思想之一,它通过将对象的创建、依赖注入和生命周期管理交给容器来实现解耦,使开发者... 目录1. IOC的基本概念1.1 什么是IOC1.2 IOC与DI的关系2. IOC的设计目标3. IOC

Python实现文件下载、Cookie以及重定向的方法代码

《Python实现文件下载、Cookie以及重定向的方法代码》本文主要介绍了如何使用Python的requests模块进行网络请求操作,涵盖了从文件下载、Cookie处理到重定向与历史请求等多个方面,... 目录前言一、下载网络文件(一)基本步骤(二)分段下载大文件(三)常见问题二、requests模块处理

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

使用TomCat,service输出台出现乱码的解决

《使用TomCat,service输出台出现乱码的解决》本文介绍了解决Tomcat服务输出台中文乱码问题的两种方法,第一种方法是修改`logging.properties`文件中的`prefix`和`... 目录使用TomCat,service输出台出现乱码问题1解决方案问题2解决方案总结使用TomCat,

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

Java中List转Map的几种具体实现方式和特点

《Java中List转Map的几种具体实现方式和特点》:本文主要介绍几种常用的List转Map的方式,包括使用for循环遍历、Java8StreamAPI、ApacheCommonsCollect... 目录前言1、使用for循环遍历:2、Java8 Stream API:3、Apache Commons