微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

React native ListView 增加顶部下拉刷新和底下点击刷新示例

1. 底部点击刷新

1.1 先增加一个按钮

rush:js;"> render() { if(!this.state.data){ return( Loading... ) }else{ return( } dataSource={this.state.data} renderRow={(rowData)=>this.renderRow(rowData)} renderFooter={this.renderFooter.bind(this)} >

);
}
}

renderFooter(){
return (
<View style={{marginVertical: 10,marginBottom:20}} >
<Button
onPress={this.addMoreOnFoot.bind(this)}
title="点击载入更多"
/>

) }

给ListView 增加一个renderFooter 方法来绘制底部元素。在里面显示一个按钮。

按钮处理逻辑:

response.json()) .then((jsondata)=>{ if (jsondata.data && jsondata.data.length > 0){ const rowData = this.state.jsondata.concat(jsondata.data); this.setState({ footLastId:jsondata.data[jsondata.data.length - 1]['id'],jsondata:rowData,data:new ListView.DataSource({rowHasChanged:(r1,r2) => r1 != r2}).cloneWithRows(rowData),}) } }) .catch((error)=>{ alert(error); }); }

点击后进行网络处理,把之前最后一条id也传给服务器,让服务器返回这个id后面的20条记录。然后重新setState即可。

2. 头部下拉刷新

ListView中增加RefeshControl

rush:js;"> render() { if(!this.state.data){ return( Loading... ) }else{ return(
 <ListView
  refreshControl={
   <RefreshControl 
     refreshing = {false}
     onRefresh = {this.reloadWordData.bind(this)}
   />
  }
  dataSource={this.state.data}
  renderRow={(rowData)=>this.renderRow(rowData)}
  renderFooter={this.renderFooter.bind(this)}
 >
  </ListView>

);
}
}

载入最新的头部数据添加到this.State中

response.json()) .then((jsondata)=>{ if (jsondata.data && jsondata.data.length > 0){ const rowData = jsondata.data.concat(this.state.jsondata); this.setState({ topLastId:jsondata.data[0]['id'],}) } }) .catch((error)=>{ alert(error); }); }

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据复制操作的两种方式。‌在聊深浅拷贝之前咱得了解一下js中的两种数据类型:
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:重建二叉树、反向输出链表每个节点 题目 重建二叉树: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列 {1,2,4,7,3,5,6,8} 和中序遍历序列 {
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须了解的知识点,现在迎来了ES6+的时代,因为箭头函数的出现,所以感觉有必要对 this 问题梳理一下,所以刚好总结一下JavaScript中this指向的问题。
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高