上期回顾
在前面的文章中我们看了进度组件ProgressIndicator的用法,怎么样大家Get了吗? 那么我们今天就来看下ProgressIndicator的应用,一起来看下Flutter中的下拉刷新与加载更多是如何实现的。
下拉刷新
在Flutter中系统已经为我们提供了google material design的刷新效果,我们可以使用RefreshIndicator组件来实现Flutter中的下拉刷新,下面们还是先来看下如何使用吧
构造方法:
代码语言:javascript复制
那么我们还是结合ListView的使用来看下举个例子
代码语言:javascript复制
首先我们还是先来回顾下ListView的用法,我们使用ListView.builder来创建了一个ListView使用 List.generate()方法来创建了一个长度为16的List,并把List里的值赋值给ListView Item中的ListTile。
那么,我们在上面的基础上加上下拉刷新组件再来试下效果。
代码语言:javascript复制
在上面的代码中我们使用_handleRefresh()方法来处理下拉刷新的回调
代码语言:javascript复制
其中 Future.delayed()方法可以选择延迟处理任务,这里我们假设网络的延迟是5秒,来看下效果。
可以看到,当我们下拉刷新结束后我们ListView的数据总数变成了40条。
接下来我们来修改下刷新进度的颜色与背景颜色再来看下效果。
当然,这个下拉刷新不是仅仅只能用在ListView中的,其他的组件都可以使用这个的。
下面我们就来介绍下如何实现ListView的上拉加载更多吧。
上拉加载更多
对于加载更多的组件在Flutter中是没有提供的,所以在这里我们就需要考虑如何实现的。
在ListView中有一个ScrollController属性,它就是专门来控制ListView滑动事件,在这里我们可以根据ListView的位置来判断是否滑动到了底部来做加载更多的处理。
在这里我们可以使用如下代码来判断ListView 是否华东到了底部
代码语言:javascript复制
_scrollController是我们初始化的ScrollController对象,通过监听我们可以判断现在的位置是否是最大的下滑位置来判断是否下滑到了底部。
下面看下代码
代码语言:javascript复制
运行效果:
是的,看着上面的效果我们已经实现了下拉加载更多,但是如果在正在请求的过程中多次下拉就会造成多次加载更多的情况,所以我们还得对这个做下处理。
代码语言:javascript复制
可以看到,我们仅仅在上面代码的基础上加上了一个isLoading的变量,当这个变量的值为true时,就不会触发加载更多的操作。
嗯,这样貌似就可以了,但是你在加载更多的过程总应该让用户看得到吧,比如给用户一个提示啊。
好吧,我们尝试在下拉的过程中给用个提示。
首先我们创建加载更多时显示的Widget
代码语言:javascript复制
其实就是一个简单的Text哈。
然后修改ListView,使得itemCount数目加1,当是最后一条时显示加载中的View,不是最后一条显示正常的Widget
代码语言:javascript复制
好吧,我们还是来看下效果:
这样我们就实现了加载更多的提示效果,当然我们也可以试试其他的效果比如
实现起来也很简单,只是替换下加载更多的Item而已
代码语言:javascript复制
当然,其他的效果大家可以根据自己的需要去自己实现哦
当然,上面的下拉刷新和加载更对可以同时用在一个ListView上面,这里就不再贴代码了,大家自己在下面试下。
小结
- RefreshIndicator可以显示下拉刷新
- 使用ScrollController可以监听滑动事件,判断当前view所处的位置
- 可以根据item所处的位置来处理加载更多显示效果
我怀疑这个是个坏掉的二维码,分享到朋友圈试试?