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

Android ListView优化之局部刷新(更新)(非notifyDataSetChanged)

在Android开发中我们经常会用到listview的数据和界面刷新动作,我们每次可能会用到的都是Adapter.notifyDataSetChanged()方法。...这样的话我们发现,getview()会调用多次,刷新了好多个不需要刷新的item,这样的话相对而言,降低了效率。但是,我们有的情况下是只需要对某个item的数据进行刷新就可以了。...局部刷新方法一:更新对应view的内容 这种方法先通过listView.getChildAt(position)拿到要更新的对应的item布局文件,然后再通过findViewById找到对应的控件进行设置...局部刷新方法二:通过ViewHolder去设置值 通过Item找出对应的ViewHolder,然后通过ViewHolder去设置值 /** * 第二种方法 找出对应的ViewHolder...局部刷新方法三:调用一次getView()方法 这种方法是调用适配器对应的getView方法,用它里面的代码对界面进行刷新

2.1K20
您找到你想要的搜索结果了吗?
是的
没有找到

ListView下拉刷新与加载更多

下拉刷新 ---- 在Flutter中系统已经为我们提供了google material design的刷新效果,我们可以使用RefreshIndicator组件来实现Flutter中的下拉刷新,下面们还是先来看下如何使用吧...构造方法: 那么我们还是结合ListView的使用来看下举个例子 首先我们还是先来回顾下ListView的用法,我们使用ListView.builder来创建了一个ListView使用 List.generate...可以看到,当我们下拉刷新结束后我们ListView的数据总数变成了40条。 接下来我们来修改下刷新进度的颜色与背景颜色再来看下效果。 ?...当然,这个下拉刷新不是仅仅只能用在ListView中的,其他的组件都可以使用这个的。 下面我们就来介绍下如何实现ListView的上拉加载更多吧。...实现起来也很简单,只是替换下加载更多的Item而已 当然,其他的效果大家可以根据自己的需要去自己实现哦 当然,上面的下拉刷新和加载更对可以同时用在一个ListView上面,这里就不再贴代码了,大家自己在下面试下

2.4K20

Flutter局部刷新优化性能

局部刷新优化性能 Flutter状态类: StatelessWidget:无状态类,没有状态更新,界面一经创建无法更改; StatefulWidget:有状态类,当状态改变,调用setState()方法会触发...案例: 当我们调用有状态类的setState方法时会遍历每一个子Widget的State.build刷新状态, 这将是一笔很大的性能开销,所以我们需要使用局部刷新来进行优化。..., 使用GlobalKey局部刷新方式 我们还是用上面的例子,只是通过GlobalKey的方式只刷新局部的Text, class TestRoute extends StatefulWidget {...setState(() => _text = count.toString()); } } 效果: 可以明显的看到按钮的count并无变动,但需要更新的文本组件更新了值,已经完美实现了局部刷新...TextWidgetState(封装的文本&&有状态类), 所以这个Key可以通过currentState方法调用到类里面的onPressed方法, 而onPressed方法刚好有调用setState来刷新局部状态

1.2K30

Flutter 组件 | ValueListenableBuilder 局部刷新小能手

解决这一问题方式是四个字:局部刷新。也就是控制 Build 的粒度,只构建刷新的部分。局部刷可以通过 provider 、flutter_bloc 等状态管理库实现。...局部刷新的思考 这样就实现了局部刷新,可以看出 Build 的时间少了很多,比起之前的全面刷新就会有所优化。注意,这里的很多帧是由于 FloatingActionButton 的水波纹效果。...水波纹的效果也是在 RawMaterialButton 被点击时通过 setState 来刷新实现的。这也是另一种局部刷新实现的方式:组件分离,将状态变化的刷新封装在组件内部,向外界提供操作接口。...另一方面,自己状态的变化仅在本组件状态内部,不会影响外界范围,即 局部刷新。 ?...触发 build 方法,从而触发 widget.builder 回调,这样就实现了局部刷新

7.5K41

【Flutter】ListView 列表高级功能 ( RefreshIndicator 下拉刷新组件 )

文章目录 一、下拉刷新组件 二、下拉刷新代码示例 三、相关资源 一、下拉刷新组件 ---- 使用 Flutter 提供的 RefreshIndicator 组件 , 可以实现下拉刷新的功能 ; 使用 RefreshIndicator...组件包裹 ListView 组件 ; 在 RefreshIndicator 构造函数中 , 设置 onRefresh 参数 , 为其设置其下拉刷新回调事件 , 当用户下拉刷新时 , 会回调该方法 ;...李应', '朱仝', '鲁智深', '武松', '董平', '张清', '杨志', '徐宁', '索超', '岱宗', '刘唐', '李逵', '史进', '穆弘' '雷横' ]; /// ListView...MaterialApp( home: Scaffold( appBar: AppBar( /// 标题组件 title: Text("ListView.../// 列表组件 body: RefreshIndicator( onRefresh: _onRefresh, child: ListView

1.4K20

android使用SwipeRefreshLayout实现ListView下拉刷新上拉加载

本文实例为大家分享了android实现ListView下拉刷新上拉加载的具体代码,供大家参考,具体内容如下 image.png 这次使用的是系统的SwipeRefreshLayout实现下拉刷新,和设置...ListView的滑动监听判断是否滑动到最底部然后加载更多; 这个要比PullToRefreshListView简单很多,想PullToRefreshListView实现下拉刷新上拉加载的可以看这篇博客...: android使用PullToRefresh框架实现ListView下拉刷新上拉加载更多 至于使用哪一种大家可以根据产品的需求选择,这两种刷新目前为止世面上还是使用PullToRefreshListView...5、setSize():设置进度圈的大小 这个大家简单了解一下,下面代码中都一一用到; 首先说下布局文件,如果想用SwipeRefreshLayout实现下拉刷新必须把ListView写到SwipeRefreshLayout...adapter; 上拉加载更多的时候直接给ListVIew设置了一个滑动监听,判断是否滑动到adapter的最下面,然后加载数据,刷新adapter; public class MainActivity

2K20
领券