SwipeableFlatList 实现类似于QQ列表滑动
import React, { Component } from "react";
import {
FlatList,
RefreshControl,
StyleSheet,
Text,
View,
ActivityIndicator,
SwipeableFlatList,
TouchableHighlight,
} from "react-native";
const CITY_NAMES = [
"河北省石家庄市",
"河北省唐山市",
"山西省太原市",
"内蒙包头市",
"辽宁省大连市",
"黑龙江省齐齐哈尔市",
"江苏省徐州市",
"浙江省杭州市",
"福建省福州市",
"江西省南昌市",
"山东省济南市",
"山东省青岛市",
"甘肃省兰州市",
"新疆乌鲁木齐市"
];
export default class SwipeableFlatListDemo extends Component {
constructor(props) {
super(props);
this.state = {
isLoading: false,
dataArray: CITY_NAMES
};
}
_renderItem(data) {
return (
<View style={styles.item}>
<Text style={styles.text}>{data.item}</Text>
</View>
);
}
loadData(refreshing) {
if(refreshing){
this.setState({
isLoading: true
});
}
setTimeout(() => {
let dataArray = [];
if(refreshing){
for (let i = this.state.dataArray.length - 1; i >= 0; i--) {
dataArray.push(this.state.dataArray[i]);
}
}else{
dataArray = this.state.dataArray.concat(CITY_NAMES);
}
this.setState({
dataArray: dataArray,
isLoading: false
});
}, 1000);
}
genIndicator() {
return <View style={styles.indicatorContainer}>
<ActivityIndicator
style={styles.indicator}
size={"large"}
animating={true}
/>
<Text>正在加载更多</Text>
</View>
}
genQuickActions(){
return <View style={styles.quickContainer}>
<TouchableHighlight
onPress={()=>{
alert('Delete?');
}}
>
<View style={styles.quick}>
<Text style={styles.text}>Delete</Text>
</View>
</TouchableHighlight>
</View>
}
render() {
return (
<View style={styles.container}>
<SwipeableFlatList
data={this.state.dataArray}
renderItem={data => this._renderItem(data)}
refreshControl={
<RefreshControl
title={"Loading"}
colors={["red"]}
tintColor={["blue"]}
refreshing={this.state.isLoading}
onRefresh={() => {
this.loadData(true);
}}
/>
}
ListFooterComponent={() => this.genIndicator()}
onEndReached={()=>this.loadData()}
renderQuickActions={()=>this.genQuickActions()}
maxSwipeDistance={100}
/>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1
},
item: {
backgroundColor: "#169",
height: 100,
marginRight: 15,
marginLeft: 15,
marginBottom: 15,
alignItems: "center",
justifyContent: "center"
},
text: {
color: "white",
fontSize: 20
},
indicatorContainer: {
alignItems: "center"
},
indicator: {
color: "red",
margin: 10
},
quickContainer:{
flex:1,
flexDirection:"row",
justifyContent:'flex-end',
marginRight:15,
marginBottom:15,
},
quick:{
backgroundColor:'red',
flex:1,
alignItems:'flex-end',
justifyContent: 'center',
padding:10,
width:200,
}
});
效果图

SwipeableFlatList 实现类似于QQ列表滑动的更多相关文章
- [Phonegap+Sencha Touch] 移动开发72 List列表横向滑动操作(仿QQ列表滑动删除)
原文链接:http://blog.csdn.net/lovelyelfpop/article/details/50425744 本插件有2个版本号:sencha touch 版本号和 extjs6 m ...
- Android 编程下代码之(QQ消息列表滑动删除)
这份代码写出来有些时候了,一直没共享,现在把它共享给大家.简单列一下代码中你可以学到的知识点: 自定义控件的实现方式: 事件的拦截分发消费机制: QQ会话列表滑动删除原理: 最后附上源码链接:Q ...
- Android-自定义仿QQ列表Item滑动
效果图: 布局中去指定自定义FrameLayout: <!-- 自定义仿QQ列表Item滑动 --> <view.custom.shangguigucustomview.MyCust ...
- iOS tableViewCell 在cell赋值、网络加载照片位置偏移大小错乱,做一个类似qq列表的tableview 更新3
更新3: 问题 加载慢!(一时间给的处理负载过大,要分散)在下载图片,判断状态后 对每个cell对图片灰置图片处理保存,影响了主线程的操作 :上拉加载时,无法上下滑动tableview 无法点击cel ...
- JS时间轴效果(类似于qq空间时间轴效果)
在上一家公司写了一个时间轴效果,今天整理了下,感觉有必要写一篇博客出来 给大家分享分享 当然代码还有很多不足的地方,希望大家多指点指点下,此效果类似于QQ空间或者人人网空间时间轴效果,当时也是为了需求 ...
- 自定义控件--CircleImageView(类似于QQ、微信圆形头像自定义控件)
现在基本上所有的需要用户注册的APP都有一个需要用户上传头像的需求,上传的头像基本都是类似于QQ.微信等社交应用圆形头像.最近,正在做的一个社交应用多处需要用到这种圆形头像的处理,总不能每次都对图片做 ...
- 一个关于如何创建类似于QQ客户端聊天窗口的模拟小项目
对于不久之前学习到的一个有关的类似于QQ聊天框的模拟项目,对其中涉及到的知识在这里做一下总结. 首先,你要先创建一个客户端聊天框(取名为:ChatClient,它是你创建的类),这个类继承了Frame ...
- 类似于qq空间类型的评论和回复
最近学习thinkphp,做了一个博客系统,其中感觉实现一个类似于qq空间的评论和回复功能比较复杂,所以把这次的经历记录下来,与大家共勉,具体的方法就不说了,在这里分享一下思路. 目标就是这种,关键是 ...
- jQuery实现的3个基础案例(仿QQ列表分组,二级联动下拉框,模拟员工信息管理系统)
1.仿QQ列表分组 <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type&quo ...
随机推荐
- 阿里云服务器 http 转 https
转载: http://blog.csdn.net/zzp961224/article/details/78934310 做个笔记 以备遗忘. 环境: 阿里云云服务器 Windows Server ...
- [转]解决-Dmaven.multiModuleProjectDirectory system property is not set. Check $M2_HOME environment variable and mvn script match.
来源:http://www.cnblogs.com/sprinng/p/5141233.html 1.添加M2_HOME的环境变量 2.Preference->Java->Installe ...
- 【Ruby】Mac gem的一些坑
前言 自上一次升级MacOS系统后出现jekyll无法构建的问题,当时处理半天.谁知道最近又升级了MacOS,荒废博客多时,今天吝啬写了一篇准备发布,构建报错,问题重新.还是记录下,以防下次升级出问题 ...
- JS如何监听动画结束
场景描述 在使用JS控制动画时一般需要在动画结束后执行回调去进行DOM的相关操作,所以需要监听动画结束进行回调.JS提供了以下事件用于监听动画的结束,简单总结学习下. CSS3动画监听事件 trans ...
- WPF中矢量图制作和引用
WPF程序有时需要适配不同大小的屏幕,图片是像素图的话,拉伸之后会变模糊,影响美观度,因此可以考虑使用矢量图.网上找到了相应的介绍:http://learnwpf.com/post/2006/06/0 ...
- mysql中trim()函数的用法
去除左空格函数: LTRIM(str) mysql> SELECT LTRIM(' barbar'); -> 'barbar' 去除右空格函数: RTRIM(str) mysql> ...
- Python_time模块
time模块:用于时间的访问和转换 UTC:协调世界时(世界统一时间) 时间戳:是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总 ...
- pycharm中出现的错误
错误1 在pycharm上安装TensorFlow运行import tensorflow时报错: File , in _find_and_load SystemError: PyEval_EvalFr ...
- appium---第三个脚本,进行模拟登陆
我这边模拟的是第三方QQ登陆 刚开始顺风顺水,启动--我的--点击头像--跳转登陆--点击QQ登陆,以上都可以通过id寻找,因为都是同一个包名下,肯定有id,如果没有,一定是技术忘记了 ..... 然 ...
- windows docker常用命令
关键词 示例 作用 attach sudo docker run -itd ubuntu:14.04 /bin/bash 进入容器 exec docker exec -it mysql bash 在容 ...