首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Flutter 专题】21 图解 ListView 下拉刷新与上滑加载(三)

和尚前段时间整理了两种 ListView 的异步加载数据时,下拉刷新与上滑加载更多的方式,每种方式都有自己的优势,网上也有很多大神讲解过 ListView 数据流的种种处理方式,和尚根据实际遇到的情况整理一下尝试的第三种方案...RefreshIndicator 下拉刷新 Flutter 提供了自带刷新效果的 RefreshIndicator,这也是网上大神们用的最多的 Widget 之一,使用方式也很简单,RefreshIndicator...ScrollController 上滑动加载更多 至此,列表的下拉刷新就完成了,接下来处理【上滑加载更多】,这时我们可以借助 ScrollController,用来监听列表是否滑动到底部,主要分两步...: RefreshIndicator( onRefresh: _loadRefresh, child: ListView.builder( itemCount:...优化二:第一次初始化加载数据时添加 loading 动画 RefreshIndicator 中自带刷新的动画,所以和尚只是在第一次加载数据时添加一个 loading 动画,和尚只是填了一个小小的状态判断

1.3K41
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ListView下拉刷新与加载更多

    下拉刷新 ---- 在Flutter中系统已经为我们提供了google material design的刷新效果,我们可以使用RefreshIndicator组件来实现Flutter中的下拉刷新,下面们还是先来看下如何使用吧...构造方法: 那么我们还是结合ListView的使用来看下举个例子 首先我们还是先来回顾下ListView的用法,我们使用ListView.builder来创建了一个ListView使用 List.generate...上拉加载更多 ---- 对于加载更多的组件在Flutter中是没有提供的,所以在这里我们就需要考虑如何实现的。...可以看到,我们仅仅在上面代码的基础上加上了一个isLoading的变量,当这个变量的值为true时,就不会触发加载更多的操作。...小结 ---- RefreshIndicator可以显示下拉刷新 使用ScrollController可以监听滑动事件,判断当前view所处的位置 可以根据item所处的位置来处理加载更多显示效果

    2.5K20

    Android开发者的Flutter入门(二)

    下拉刷新 添加一个Material design风格的下拉刷新比较简单,直接给列表包一个RefreshIndicator就可以了 return RefreshIndicator(...//触发的回调 onRefresh: _onRefresh, child: ListView.builder() ) 下拉刷新触发的回调通过onRefresh...下拉刷新 上拉加载更多 Flutter没有系统提供的加载更过控件,这里我们想办法做一个比较粗糙的实现。思路是在列表的末尾添加一个加载控件,当滑动到列表底部的时候触发加载的操作。...这样我们就给列表加了个上拉加载更多的功能。效果如图: ?...上拉加载更多 使用Assets 添加 Assets 在Flutter中如果你有图片等文件需要引入到app中,都需要使用Assets, 这个Assets的概念不同于Android中Assets的概念,某种意义上讲

    1.4K20

    Flutter完整开发实战详解(三、 打包与填坑篇)

    [s523e93naj.png] 从上表我们可以看到: Fluuter的 apk 会比 ipa 更小一些,这其中的一部分原因是 Flutter 使用的 Skia 在Android 上是自带的。...这里又有一个细节,rn 的 ipa 包体积小很多,这其实是因为 javascriptcore 在 ios上 是内置的原因。 对上述内容有兴趣的可以看看《移动端跨平台开发的深度解析》。...二、细节 这里主要讲一些小细节 1、AppBar 在 Flutter 中 AppBar 算是常用 Widget ,而 AppBar 可不仅仅作为标题栏和使用,AppBar上的 leading 和 bottom...4、GlobalKey 在Flutter中,要主动改变子控件的状态,还可以使用 GlobalKey。 比如你需要主动调用 RefreshIndicator 显示刷新状态,如下代码所示。...( key: refreshIndicatorKey, onRefresh: onRefresh, child: new ListView.builder(

    3.7K30

    Flutter完整开发实战详解(三、 打包与填坑篇)

    apk 会比 ipa 更小一些,这其中的一部分原因是 Flutter 使用的 Skia 在Android 上是自带的。...这里又有一个细节,rn 的 ipa 包体积小很多,这其实是因为 javascriptcore 在 ios上 是内置的原因。 对上述内容有兴趣的可以看看《移动端跨平台开发的深度解析》。...二、细节 这里主要讲一些小细节 1、AppBar 在 Flutter 中 AppBar 算是常用 Widget ,而 AppBar 可不仅仅作为标题栏和使用,AppBar上的 leading 和 bottom...4、GlobalKey 在Flutter中,要主动改变子控件的状态,还可以使用 GlobalKey。 比如你需要主动调用 RefreshIndicator 显示刷新状态,如下代码所示。...( key: refreshIndicatorKey, onRefresh: onRefresh, child: new ListView.builder(

    1.6K10

    Flutter | 滚动组件,ListView,GridVIew等

    由于可滚动组件的默认方向一般都是沿垂直方向,所以默认情况下主轴就是指垂直方向,水平方向同理 SingleChildScrollView SingleChildScrollView 类似于 Android...的 长度为 itemExtent 的值;这里的长度指的是方向上子组件的长度,也就是说滚动的是垂直方向,则 itemnExtent 代表子组件的高度;如果是水平方向,则是子组件的宽度。...,这是一个通用的规律,并非 ListView 自己的特性,想 GridView 也是如此 ListView.builder 这种适合列表项比较多(或者无限) 的情况,因为只有当子组件真正显示的时候才会被创建...,也就是说改构造函数是支持基于 Sliver 的懒加载模型的;下面看一下核心参数: ListView.builder({ // ListView公共参数已省略 ......e.asPascalCase) .toList()); }) }); } } 复制代码 效果如下: 实现下拉刷新 RefreshIndicator

    8.7K20
    领券