ListView简单实例

当我们要做一些列表 我想ListView是再适合不过的组件了 在RN里面算是一个核心组件,用于高效地显示一个可以垂直滚动的变化的数据列表。
废话不多说 开始来做吧

第一步

如果我们要做一个列表 那么我们先要做出 里面里面每个item吧
Item代码如下:List.js

import React from 'react';
import {
  StyleSheet,
  Text,
  View,
  Image,
  TouchableHighlight
} from 'react-native';

export default class List extends React.Component {
  constructor(props) {
    super(props);
  }

  render() {
    return (
      <TouchableHighlight 
        style={styles.tbox}
        underlayColor='#fff'
        onPress={()=>{}}>
        <View style={styles.box}>
            <Image source={{uri:this.props.src}} style={styles.img} />
            <View style={styles.txt}>
                <Text style={styles.title}>{this.props.title}</Text>
                <Text style={styles.time}>{this.props.time} | {this.props.id}</Text>
            </View>
        </View>
      </TouchableHighlight>
    );
  }
}

const styles = StyleSheet.create({
  tbox:{
    backgroundColor:'#f5f5f5',
  },
  box:{
    flexDirection:'row',
    padding:5,
    borderBottomWidth:1,
    borderColor:'#eee',
  },
  img:{
    flex:3.8,
    resizeMode:Image.resizeMode.contain,
    height:100
  },
  txt:{
    flex:6.2,
    paddingLeft:8,
    paddingRight:3,
  },
  title:{
    lineHeight:22,
  },
  time:{
    marginTop:30,
    color:'#999'
  }
});

很简单 单个的item就做好了 它的样子应该是这样的

List

第二步

我们要开始做ListView了
新建一个文件叫Main.js
首先在我们在构造函数里 定义我们的state

constructor(props) {
    super(props);

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

然后我们要加载数据 一般加载数据我会在组件渲染完成后执行也就是componentDidMount里面 这里载入数据的我用的是fetch 代码如下:

componentDidMount() {
    fetch('http://ued.yihaodian.com:3001/api/70')
      .then((response) => response.json())
      .then((data) => {
        this.setState({
          dataSource:this.ds.cloneWithRows(data.listData)
        })
      })
      .done();
}

数据应该长这样:


api data

后面就是把List模块渲染到ListView里面去了

rendList(data){
    return (
      <List
        src={data.src}
        title={data.title}
        time={data.time}
        id={data.id} />
    )
}

...

render() {
    return (
        <ListView
          dataSource={this.state.dataSource}
          renderRow={this.rendList}  />
    );
}

最终效果图:

Paste_Image.png

那么一个简单的ListView的实例就完成了
后面我会讲一下ListView如何实现下拉时动态渲染数据

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,888评论 25 709
  • 前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人...
    珍此良辰阅读 14,565评论 11 24
  • 当亮哥带着穿警服的王警官来到李部长面前时,李部长着实吓了一跳。 “哎呦,这不是张经理吗?”李部长赶紧站起来,伸出双...
    鲁郡阅读 1,521评论 0 2
  • 3阅读书目《刻意练习》 阅读时间:1小时 阅读页码:1--46页 学习收获:这个曾经在互联网流传着一个错误概念:1...
    Juzid055阅读 1,391评论 0 0