React-Native学习系列(四)-ListView&Fetch()

前言

去年我写了一个教程,手把手教你写一个RN小程序!,里面其实对ListView已经做了一些详解,不过由于那个项目接口停止维护,再加上RN教程准备写一个系列,所以重新写一篇文章来完善ListView的使用。另外,ListView一般都是配合数据来使用的,所以这里我把网络请求也顺带简单的讲解一下。本文会使用豆瓣api来进行数据的解析。

fetch()

React Native提供了和web标准一致的Fetch API,用于满足开发者访问网络的需求。那么如何使用呢?

fetch使用

fetch('https://api.douban.com/v2/movie/top250')//豆瓣电影Top250

从任意地址获取数据,只需要这么写就可以了,把地址传递给fetch()方法。

  fetch('https://api.douban.com/v2/movie/top250')
    //ES6的写法左边代表输入的参数右边是逻辑处理和返回结果
    .then((response) => response.json())
    .then((responseData) => {
       this.setState({
         data: responseData,
         });
       })
    .done();  

以上是fetch通过get请求获取的数据,这个可以获取数据源data,那么我们登录注册一般都是用的post提交方式,那该如何写呢?
fetch()还有可选的第二个参数用来指定请求的方法,你可以指定header参数,或是指定使用POST方法,又或是提交数据等等。

fetch('https://mywebsite.com/endpoint/', {
  method: 'POST',//指定POST方法
  headers: {//指定header参数
    'Accept': 'application/json',
    'Content-Type': 'application/json',
  },
 body: JSON.stringify({//设置提交的数据
    firstParam: 'yourValue',
    secondParam: 'yourOtherValue',
})
}) 
.then((response) => response.json())  
.then((responseData) => {
    //responseData是服务器返回的data
}

})
  .done();  

简单的fetch()请求就介绍到这里,有想法的同学可以参考该文章:【翻译】这个API很“迷人”——(新的Fetch API)

温馨提示,iOS默认不支持http请求,请在Xcode中设置

1、在Info.plist中添加NSAppTransportSecurity类型Dictionary。

2、在NSAppTransportSecurity下添加NSAllowsArbitraryLoads类型Boolean,值设为YES

组件生命周期

一般来说,一个组件类由 extends Component创建,并且提供一个 render方法以及其他可选的生命周期函数、组件相关的事件或方法来定义。

getInitialState()函数 初始化 this.state 的值,只在组件装载之前调用一次。
getDefaultProps()函数 只在组件创建时调用一次并缓存返回的对象,因为这个方法在实例初始化之前调用,所以在这个方法里面不能依赖 this 获取到这个组件的实例。
render() 组装生成这个组件的 HTML 结构 ,必须要有的函数

生命周期函数

componentWillMount() 只会在装载之前调用一次,在 render 之前调用,你可以在这个方法里面调用 setState 改变状态
componentDidMount() 只会在装载完成之后调用一次,在 render 之后调用,从这里开始可以通过 ReactDOM.findDOMNode(this) 获取到组件的 DOM 节点。
componentWillUnmount() 卸载组件触发
更新组件时触发的函数:
componentWillReceiveProps()
shouldComponentUpdate()
componentWillUpdate()
componentDidUpdate

ListView

ListView是一个常用核心组件,用于高效地显示一个可以垂直滚动的变化的数据列表。通过创建一个ListView.DataSource数据源,然后给它传递一个普通的数据数组,再使用数据源来实例化一个ListView组件,并且定义它的renderRow回调函数,这个函数会接受数组中的每个数据作为参数,返回一个可渲染的组件(作为listview的每一行)。

cellRow(data) {
  return (
      <View >//这个是cell的视图
      </View>
  );  
 }

render() {
    return (
     <View style={styles.container}>
     <ListView
            initiaListSize={1} //指定在组件刚挂载的时候渲染多少行数据。用来确保首屏显示合适数量的数据
            //onChangeVisibleRows={()=>{}}//当可见的行的集合变化的时候调用此回调函数  
            //onEndReached={()=>{}}//当所有的数据都已经渲染过,并且列表被滚动到距离最底部不足onEndReachedThreshold个像素的距离时调用。配合onEndReachedThreshold使用
            onEndReachedThreshold={10} //调用onEndReached之前的临界值,单位是像素。
            pageSize={3} //每次渲染的行数
            removeClippedSubviews={true}//用于提升大列表的滚动性能。需要给行容器添加样式overflow:'hidden'。(Android已默认添加此样式)。此属性默认开启。
            dataSource={this.state.dataSource} //列表依赖的数据源
            renderRow={this.cellRow.bind(this)}//(rowData, sectionID, rowID, highlightRow) => renderable 从数据源(Data source)中接受一条数据,以及它和它所在section的ID。返回一个可渲染的组件来为这行数据进行渲染。
            style={styles.listView}
     />
     </View>
    );
 }  

renderSectionHeader()方法会为每个section提供一个粘性的标题
scrollTo(...args),滚动到指定的x,y偏移处。

ListView和Fetch()结合使用

1.新建一个文件

import React, { Component } from 'react';
import {
StyleSheet,
Text,
View,
ListView
} from 'react-native';
export default class TestDemo extends Component {
render() {
    return (
    <View style={styles.container}>
    </View>
    );
}
}
const styles = StyleSheet.create({
container:{
flex:1,
}
});  

2.引入ListView

<ListView initiaListSize={2}
          pageSize={2}
          dataSource={this.state.dataSource}
          renderRow={this.cellRow.bind(this)}
          style={styles.listView}
/>  

然后根据文档添加数据源dataSource

constructor(props){
super(props);
const ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
this.state = {dataSource: ds.cloneWithRows([{},])};
}  

我们的Cell也必定不能少啊

cellRow(data) {
    return (
        <TouchableOpacity onPress={()=>this.rowPressed(data)}>
      <View>
        <View style={styles.cellStyle}>
            <Image style={{margin:10,width:100, resizeMode:'contain',height:(WIDTH-40)/2}}
                   source={{uri: data.images.large}}
            />
            <Text style={styles.title}>{data.title}</Text>
        </View>
      </View>
    </TouchableOpacity>
    );
}  

OK基本上完工,说好的fetch呢?别着急,慢慢来

componentDidMount() {
    this.fetchData();
}
fetchData() {
    fetch(GET_URL)
        //ES6的写法左边代表输入的参数右边是逻辑处理和返回结果
        .then((response) => response.json())
        .then((responseData) => {
            if (responseData.subjects) {
            //我们需要在数据解析完成的时候来setdataSource
                this.setState({
                    dataSource: this.state.dataSource.cloneWithRows(responseData.subjects),
                });
            } else {
                //do Something 
                Alert.alert('暂时没有数据');
            }
        })

    .done
}

恩,测试的话,GET_URL是https://api.douban.com/v2/movie/top250,
至此基本上已经完工,大家可以试着做一下

from Demon404

)

最后

当然要附上我们的源码了,在我的github上:React-Native-Study
后续会更新带Header的ListView和用ListView写的九宫格,喜欢的同学可以支持一下,么么哒!

from Demon404
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容