首页
学习
活动
专区
工具
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.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ListView下拉刷新与加载更多

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

    2.5K20

    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.3K30

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

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

    8K41

    Flutter局部刷新三剑客

    局部刷新作为提高Flutter页面性能的重要手段,是每一个Flutter老手都必须掌握的技巧。...当然,我们不用非得使用Riverpod、Provider、Bloc这些状态管理工具来实现局部刷新,Flutter框架本身也给我们提供了很多方便快捷的刷新方案,今天要提的就是Notifier三剑客,用它来处理局部刷新...这样就形成了一个响应式的基础模型,数据修改,监听者刷新UI,完成了响应式的同时,也实现了局部刷新的功能,提高了性能。...dart onPressed: () => _countNotify.value = Wrapper(age: 10), 自定义类型局部刷新 上面这种自定义模型的刷新方法还是略显复杂了一点,每次更新的时候...value.age++; notifyListeners(); } } // 调用处 _countNotify.increment(); 通过这种方式,我们可以实现当模型内部变量更新时,局部进行刷新

    24610

    【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.9K20

    Android自定义控件ListView下拉刷新的代码

    ListView在实际实用中,一般都会有下新刷新和上拉加载的动态效果,今天要学的就是如何自定义带下拉刷新ListView。...原理解析:一般将有下拉刷新listview分成四种不同的状态来进行不同的显示效果。...1.完成状态done:listview正常显示状态 2.下拉状态pull:listview正在下拉时的状态 3.释放状态release:listview下拉后松开的状态 4.更新状态refreshing...:listview下拉后加载数据时的状态 实现步骤: 自定义CustomListView继承自ListView,添加headerView,里面的布局是有下拉刷新的文字与图片 为listview创建适配器...("刷新中");// 改变文字 提示 currentState = STATE_REFRESHING;// 改变状态,变为刷新状态 ivArrow.setVisibility(GONE);// 箭头隐藏

    1.4K20
    领券