标签:
‘use strict‘;
import React, { Component } from ‘react‘;
import {
AppRegistry,
ScrollView,
StyleSheet,
Text,
View,
RefreshControl,
} from ‘react-native‘;
class ListRowComponent extends React.Component{
render(){
return (
<View style={styles.row}>
<Text style={styles.text}>
{this.props.data.text}
</Text>
</View>
);
}
};
class MyProject extends Component {
constructor(props) {
super(props);
this.state = {
isRefreshing: false,
loaded: 0,
rowData: Array.from(new Array(10)).map(
(val, i) => ({text: ‘初次加载的数据行 ‘ + i})),
};
}
render() {
var rows = this.state.rowData.map((row, indexKey) => {
return <ListRowComponent key={indexKey} data={row}/>;
});
return (
<ScrollView style={styles.scrollview} refreshControl={
<RefreshControl
refreshing={this.state.isRefreshing}
onRefresh={this.onRefresh.bind(this)} //(()=>this.onRefresh)或者通过bind来绑定this引用来调用方法
tintColor=‘red‘
title= {this.state.isRefreshing? ‘刷新中....‘:‘下拉刷新‘}
/>
}>
{rows}
</ScrollView>
);
}
onRefresh() {
this.setState({isRefreshing: true});
setTimeout(() => {
// 准备下拉刷新的5条数据
var rowNewData = Array.from(new Array(5))
.map((val, i) => ({
text: ‘下拉刷新增加的数据行 ‘ + (+this.state.loaded + i)
}))
.concat(this.state.rowData);
this.setState({
loaded: this.state.loaded + 5,
isRefreshing: false,
rowData: rowNewData,
});
}, 2000);
}
}
const styles = StyleSheet.create({
row: {
borderColor:‘green‘,
borderWidth:5,
padding:20,
backgroundColor:‘#3a5795‘,
margin:5,
},
text:{
alignSelf:‘center‘,
color:‘white‘,
},
scrollerview:{
flex:1,
}
});
AppRegistry.registerComponent(‘MyProject‘, () => MyProject);
效果演示图:
参考案例:
http://www.lcode.org/%E3%80%90react-native%E5%BC%80%E5%8F%91%E3%80%91react-native%E6%8E%A7%E4%BB%B6%E4%B9%8Brefreshcontrol%E7%BB%84%E4%BB%B6%E8%AF%A6%E8%A7%A321/
react native - RefreshControl 使用案例
标签:
原文地址:http://www.cnblogs.com/thbbsky/p/5772460.html