# <refresh>
简介
<refresh>
为容器提供下拉刷新功能。
注意
<refresh>
是<scroller>
、<list>
、<waterfall>
的子组件,只能在被它们包含时才能被正确渲染。
<scroller>
<refresh>
<text>Refreshing...</text>
</refresh>
<div v-for="num in lists">
<text>{{num}}</text>
</div>
</scroller>
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# 子组件
- 诸如
<text>
、<image>
之类的任何组件,都可以放到<loading>
进行渲染。 - 特殊子组件
<loading-indicator>
: 只能作为<refresh>
和<loading>
的子组件使用,拥有默认的动画效果实现。
<refresh>
<text>Refreshing</text>
<loading-indicator></loading-indicator>
</refresh>
1
2
3
4
2
3
4
# 属性
display
控制<refresh>
组件显示、隐藏。display
的设置必须成对出现,即设置display="show"
,必须有对应的display="hide"
。可选值为show / hide
,默认值为show
。
# 事件
refresh
事件:当<scroller>
、<list>
、<waterfall>
被下拉完成时触发。pullingdown
事件:当<scroller>
、<list>
、<waterfall>
被下拉时触发。 可以从 event 参数对象中获取以下数据:dy
: 前后两次回调滑动距离的差值pullingDistance
: 下拉的距离viewHeight
: refresh 组件高度type
: “pullingdown” 常数字符串
<refresh @refresh="onrefresh" @pullingdown="onpullingdown" :display="refreshing ? 'show' : 'hide'">
<text>Refreshing ...</text>
<loading-indicator></loading-indicator>
</refresh>
1
2
3
4
2
3
4
# Vue 示例
# Rax 示例
rax-refreshcontrol
是 <refresh>
组件的上层封装,提供了 Weex 下拉刷新能力
import { createElement, Component, render } from 'rax';
import View from 'rax-view';
import Text from 'rax-text';
import Driver from 'driver-universal';
import RecyclerView from 'rax-recyclerview';
import RefreshControl from 'rax-refreshcontrol';
class RefreshControlDemo extends Component {
state = {
isRefreshing: false,
loaded: 0,
refreshText: '↓ Pull To Refresh'
};
handleRefresh = (e) => {
this.setState({
isRefreshing: true,
refreshText: 'Refreshing',
});
setTimeout(() => {
// update Data
this.setState({
isRefreshing: false,
refreshText: '↓ Pull To Refresh',
});
}, 1000);
};
render() {
return (
<View>
<RecyclerView
refreshControl={null}>
<RefreshControl
refreshing={this.state.isRefreshing}
onRefresh={this.handleRefresh}
>
<Text>{this.state.refreshText}</Text>
</RefreshControl>
<RecyclerView.Cell>
<View>
<Text>this is list</Text>
</View>
</RecyclerView.Cell>
</RecyclerView>
</View>
);
}
}
render(<RefreshControlDemo/>, document.body, { driver: Driver });
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51