全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

React Native之ListView实现九宫格效果的示例

概述

在安卓原生开发中,ListView是很常用的一个列表控件,那么React Native(RN)如何实现该功能呢?我们来看一下ListView的源码

ListView是基于ScrollView扩展得来的,所以具有ScrollView的相关属性:

dataSource:数据源,类似于安卓中我们传入BaseAdapter的数据集合。

renderRow:渲染某一行,类似于BaseAdapter中的getItem方法。

onEndReached:简单说就是用于分页操作,在安卓中原生开发中,我们需要自己实现相应的方法。

onEndReachedThreshold:调用onEndReached之前的临界值,单位是像素。

refreshControl:指定RefreshControl组件,用于为ScrollView提供下拉刷新功能。(该属性是继承与ScrollView)

renderHeader:渲染头部View,类似于安卓ListView中的addHeader.

以上的属性基本可以解决一些常见的列表需求,如果我们想要实现网格的效果,也可以借助该组件来实现,有点类似于安卓中的RecyclerView控件。

pageSize:渲染的网格数,类似于安卓GridView中的numColumns.

contentContainerStyle:该属性是继承于ScrollView,主要作用于该组件的内容容器上。

要用ListView实现九宫格的效果:

1,配置pageSize确认网格数量

<ListView  
   automaticallyAdjustContentInsets={false}  
   contentContainerStyle={styles.grid}  
   dataSource={this.state.dataSource}  
   renderRow={this.renderRow.bind(this)}  
   pageSize={3}  
   refreshControl={  
     <RefreshControl  
      onRefresh={this.onRefresh.bind(this)}  
      refreshing={this.state.isLoading}  
      colors={['#ff0000', '#00ff00', '#0000ff']}  
      enabled={true}  
      />  
    }  
   />  

2,设置每一个网格的宽度样式

itemLayout:{  
  flex:1,  
  width:Util.size.width/3,  
  height:Util.size.width/3,  
  alignItems:'center',  
  justifyContent:'center',  
  borderWidth: Util.pixel,  
  borderColor: '#eaeaea'  
 },  

3,设置contentContainerStyle相应属性

grid: {  
  justifyContent: 'space-around',  
  flexDirection: 'row',  
  flexWrap: 'wrap'  
 },  

这里需要说明下,由于ListView的默认方向是纵向的,所以需要设置ListView的contentContainerStyle属性,添加flexDirection:‘row'。其次,ListView在同一行显示,而且通过flexWrap:'wrap'设置自动换行。

注:flexWrap属性:wrap、nowrap,wrap:空间不足的情况下自动换行,nowrap:空间不足,压缩容器,不会自动换行。

以下是完整代码:

 import React, { Component } from 'react'; 
import { 
  AppRegistry, 
  StyleSheet, 
  Text, 
  View, 
  ListView, 
  Image, 
  TouchableOpacity, // 不透明触摸 
  AlertIOS 
} from 'react-native'; 
 
// 获取屏幕宽度 
var Dimensions = require('Dimensions'); 
const screenW = Dimensions.get('window').width; 
 
// 导入json数据 
var shareData = require('./shareData.json'); 
 
// 一些常亮设置 
const cols = 3; 
const cellWH = 100; 
const vMargin = (screenW - cellWH * cols) / (cols + 1); 
const hMargin = 25; 
 
// ES5 
var ListViewDemo = React.createClass({ 
  // 初始化状态值(可以变化) 
  getInitialState(){ 
    // 创建数据源 
    var ds = new ListView.DataSource({rowHasChanged:(r1,r2) => r1 !== r2}); 
    return{ 
      dataSource:ds.cloneWithRows(shareData.data) 
    } 
  }, 
 
  render(){ 
    return( 
      <ListView 
        dataSource={this.state.dataSource} 
        renderRow={this.renderRow} 
        contentContainerStyle={styles.listViewStyle} 
      /> 
    ); 
  }, 
 
  // 返回cell 
  renderRow(rowData){ 
    return( 
      <TouchableOpacity activeOpacity={0.8} onPress={()=>{AlertIOS.alert('点击了')}} > 
        <View style={styles.innerViewStyle}> 
          <Image source={{uri:rowData.icon}} style={styles.iconStyle} /> 
          <Text>{rowData.title}</Text> 
        </View> 
      </TouchableOpacity> 
    ); 
  }, 
}); 
 
const styles = StyleSheet.create({ 
  listViewStyle:{ 
    // 主轴方向 
    flexDirection:'row', 
    // 一行显示不下,换一行 
    flexWrap:'wrap', 
    // 侧轴方向 
    alignItems:'center', // 必须设置,否则换行不起作用 
  }, 
 
  innerViewStyle:{ 
    width:cellWH, 
    height:cellWH, 
    marginLeft:vMargin, 
    marginTop:hMargin, 
    // 文字内容居中对齐 
    alignItems:'center' 
  }, 
 
  iconStyle:{ 
    width:80, 
    height:80, 
  }, 
 
}); 
 
AppRegistry.registerComponent('ListViewDemo', () => ListViewDemo); 

效果如图(数据源自己加)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# React  # Native  # 实现九宫格  # 九宫格  # ReactNative列表ListView的用法  # React-Native实现ListView组件之上拉刷新实例(iOS和Android通用)  # 类似于  # 换行  # 临界值  # 要用  # 分页  # 如图  # 来实现  # 得来  # 大家多多  # 如何实现  # 设置自动  # 作用于  # 不透明  # 不起作用  # 情况下  # 是基于  # borderWidth  # colors  # state 


相关文章: 如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  网站制作难吗安全吗,做一个网站需要多久时间?  php json中文编码为null的解决办法  电商网站制作公司有哪些,1688网是什么意思?  如何在云指建站中生成FTP站点?  非常酷的网站设计制作软件,酷培ai教育官方网站?  广州美橙建站如何快速搭建多端合一网站?  表情包在线制作网站免费,表情包怎么弄?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  如何使用Golang table-driven基准测试_多组数据测量函数效率  XML的“混合内容”是什么 怎么用DTD或XSD定义  c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】  如何在七牛云存储上搭建网站并设置自定义域名?  建站org新手必看:2024最新搭建流程与模板选择技巧  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  小型网站制作HTML,*游戏网站怎么搭建?  如何选择靠谱的建站公司加盟品牌?  如何在Golang中指定模块版本_使用go.mod控制版本号  如何通过VPS建站无需域名直接访问?  如何通过.red域名打造高辨识度品牌网站?  制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?  在线制作视频网站免费,都有哪些好的动漫网站?  如何在橙子建站上传落地页?操作指南详解  网站制作报价单模板图片,小松挖机官方网站报价?  制作宣传网站的软件,小红书可以宣传网站吗?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何在Windows 2008云服务器安全搭建网站?  番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?  如何选择CMS系统实现快速建站与SEO优化?  成都网站制作报价公司,成都工业用气开户费用?  建站之星如何优化SEO以实现高效排名?  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  如何高效完成独享虚拟主机建站?  ,如何利用word制作宣传手册?  如何选择适合PHP云建站的开源框架?  公司网站设计制作厂家,怎么创建自己的一个网站?  网站专业制作公司有哪些,做一个公司网站要多少钱?  如何高效生成建站之星成品网站源码?  制作电商网页,电商供应链怎么做?  北京网站制作的公司有哪些,北京白云观官方网站?  建站三合一如何选?哪家性价比更高?  江苏网站制作公司有哪些,江苏书法考级官方网站?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  如何快速启动建站代理加盟业务?  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  如何彻底卸载建站之星软件?  深入理解Android中的xmlns:tools属性 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。