iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Android ListView列表怎么优化
  • 175
分享到

Android ListView列表怎么优化

2023-06-30 14:06:05 175人浏览 安东尼
摘要

这篇文章主要讲解了“Android ListView列表怎么优化”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android ListView列表怎么优化”吧!优化点1:

这篇文章主要讲解了“Android ListView列表怎么优化”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android ListView列表怎么优化”吧!

优化点1:使用 builder构建列表

当你的列表元素是动态增长的时候(比如上拉加载更多),请不要直接用children 的方式,一直往children 的数组增加组件,那样会很糟糕。

//糟糕的用法ListView(  children: [    item1,    item2,    item3,    ...  ],)//正确的用法ListView.builder(  itemBuilder: (context, index) => ListItem(),  itemCount: itemCount,)

对于 ListView.builder 是按需构建列表元素,也就是只有那些可见的元素才会调用itemBuilder 构建元素,这样对于大列表而言性能开销自然会小很多。

Creates a scrollable, linear array of widgets that are created on demand. This constructor is appropriate for list views with a large (or infinite) number of children because the builder is called only for those children that are actually visible.

优化点2:禁用 addAutomaticKeepAlives 和 addRepaintBoundaries 特性

这两个属性都是为了优化滚动过程中的用户体验的。addAutomaticKeepAlives 特性默认是 true,意思是在列表元素不可见后可以保持元素的状态,从而在再次出现在屏幕的时候能够快速构建。这其实是一个拿空间换时间的方法,会造成一定程度的内存开销。可以设置为 false 关闭这一特性。缺点是滑动过快的时候可能会出现短暂的白屏(实际会很少发生)。

addRepaintBoundaries 是将列表元素使用一个重绘边界(Repaint Boundary)包裹,从而使得滚动的时候可以避免重绘。而如果列表很容易绘制(列表元素布局比较简单的情况下)的时候,可以关闭这个特性来提高滚动的流畅度。

addAutomaticKeepAlives: false,addRepaintBoundaries: false,

优化点3:尽可能将列表元素中不变的组件使用 const 修饰

使用 const 相当于将元素缓存起来实现共用,若列表元素某些部分一直保持不变,那么可以使用 const 修饰。

return Padding(  child: Row(    children: [      const ListImage(),      const SizedBox(        width: 5.0,      ),      Text('第$index 个元素'),    ],  ),  padding: EdgeInsets.all(10.0),);

优化点4:使用 itemExtent 确定列表元素滚动方向的尺寸

对于很多列表,我们在滚动方向上的尺寸是提前可以根据 UI设计稿知道的,如果能够知道的话,那么使用 itemExtent 属性制定列表元素在滚动方向的尺寸,可以提升性能。这是因为,如果不指定的话,在滚动过程中,会需要推算每个元素在滚动方向的尺寸从而消耗计算资源。

itemExtent: 120,

优化实例

下面是一开始未改造的列表,嗯,可以认为是垃圾代码

class LargeListView extends StatefulWidget {  const LargeListView({Key? key}) : super(key: key);  @override  _LargeListViewState createState() => _LargeListViewState();}class _LargeListViewState extends State<LargeListView> {  @override  Widget build(BuildContext context) {    return Scaffold(      appBar: AppBar(        title: Text('大列表'),        brightness: Brightness.dark,      ),      body: ListView(        children: List.generate(          1000,          (index) => Padding(            padding: EdgeInsets.all(10.0),            child: Row(              children: [                Image.network(                  'https://file.lsjlt.com/upload/202306/28/uogn1xvfgp3.jpg',                  width: 200,                ),                const SizedBox(                  width: 5.0,                ),                Text('第$index 个元素'),              ],            ),          ),        ),      ),    );  }}

当然,实际不会是用 List.generate 来生成列表元素,但是也不要用一个 List<Widget> 列表对象一直往里面加列表元素,然后把这个列表作为 ListView 的 children!改造后的代码如下所示,因为将列表元素拆分得更细,代码量是多一些,但是性能上会好很多。

import 'package:Flutter/material.dart';class LargeListView extends StatefulWidget {  const LargeListView({Key? key}) : super(key: key);  @override  _LargeListViewState createState() => _LargeListViewState();}class _LargeListViewState extends State<LargeListView> {  @override  Widget build(BuildContext context) {    return Scaffold(      appBar: AppBar(        title: Text('大列表'),        brightness: Brightness.dark,      ),      body: ListView.builder(        itemBuilder: (context, index) => ListItem(          index: index,        ),        itemCount: 1000,        addAutomaticKeepAlives: false,        addRepaintBoundaries: false,        itemExtent: 120.0,      ),    );  }}class ListItem extends StatelessWidget {  final int index;  ListItem({Key? key, required this.index}) : super(key: key);  @override  Widget build(BuildContext context) {    return Padding(      child: Row(        children: [          const ListImage(),          const SizedBox(            width: 5.0,          ),          Text('第$index 个元素'),        ],      ),      padding: EdgeInsets.all(10.0),    );  }}class ListImage extends StatelessWidget {  const ListImage({Key? key}) : super(key: key);  @override  Widget build(BuildContext context) {    return Image.network(      'Https://file.lsjlt.com/upload/202306/28/uogn1xvfgp3.jpg',      width: 200,    );  }}

感谢各位的阅读,以上就是“Android ListView列表怎么优化”的内容了,经过本文的学习后,相信大家对Android ListView列表怎么优化这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: Android ListView列表怎么优化

本文链接: http://www.lsjlt.com/news/329555.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android ListView列表怎么优化
    这篇文章主要讲解了“Android ListView列表怎么优化”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android ListView列表怎么优化”吧!优化点1:...
    99+
    2023-06-30
  • Android ListView列表优化的方法详解
    1. 使用ViewHolder模式:该模式可以减少findViewById的调用次数。在getView()方法中,通过ViewHol...
    99+
    2023-08-14
    Android
  • Android ListView列表优化的方法有哪些
    优化Android ListView列表的方法有以下几种:1. 使用ViewHolder模式:在getView()方法中使用View...
    99+
    2023-08-14
    Android ListView
  • 如何优化Android中的ListView
    如何优化Android中的ListView?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。ListView的优化对于ListView来说,应该算是布局中几种最常用的组件之一了,使...
    99+
    2023-05-31
    android listview roi
  • Android ListView实现简单列表功能
    ListView如何实现简单列表,供大家参考,具体内容如下效果图:啥也没干的ListView张这样:fry.Activity01package fry;import com.example.ListView.R;import android...
    99+
    2023-05-30
    listview 列表 roi
  • Android之ListView优化技巧有哪些
    以下是一些优化Android中ListView的技巧:1. 使用ViewHolder模式:在getView()方法中使用ViewHo...
    99+
    2023-09-25
    Android ListView
  • Android Studio 中列表视图(ListView)的应用
    目录 引言 一、列表视图的作用 二、列表视图的工作原理和工作方式 三、准备数据源 四、适配器的使用 五、布局文件中的列表视图 六、自定义列表项布局 七、列表项点击事件处理 八、列表的优化 十、示例代码和演示 十一、总结和展望 参考资料: ...
    99+
    2023-09-11
    android 学习
  • QT怎么制作一个ListView列表
    这篇文章主要介绍“QT怎么制作一个ListView列表”,在日常操作中,相信很多人在QT怎么制作一个ListView列表问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”QT怎么制作一个ListView列表”的疑...
    99+
    2023-07-05
  • 怎么清空listview更新列表内容
    要清空一个ListView并更新列表内容,你可以按照以下步骤操作:1. 获取ListView的数据源,比如一个ArrayList。2...
    99+
    2023-09-14
    listview
  • ListView列表组件如何在Android项目中使用
    ListView列表组件如何在Android项目中使用?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。ListView是一种非常常见的一个组件,以垂直列表的形式显示列表项。而...
    99+
    2023-05-31
    android listview roi
  • Android性能优化系列篇UI优化
    目录前言一、UI优化1.1 系统做的优化1.1.1 硬件加速1.2 优化方案1.2.1 java代码布局1.2.2 View重用1.2.3 异步创建view1.2.4 xml布局优化...
    99+
    2022-11-13
    Android性能UI优化 Android UI优化
  • Vue怎么优化无限滚动列表
    这篇文章主要介绍“Vue怎么优化无限滚动列表”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue怎么优化无限滚动列表”文章能帮助大家解决问题。问题大家都知道,Web 页面修改 DOM 是开销较大的操...
    99+
    2023-07-04
  • listview在android中使用怎么实现多列模版
    listview在android中使用怎么实现多列模版?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。android listview多列模版<LinearLayout...
    99+
    2023-05-31
    android listview roi
  • Android 性能优化系列之bitmap图片优化
    背景 Android开发中,加载图片过多、过大很容易引起OutOfMemoryError异常,即我们常见的内存溢出。因为Android对单个应用施加内存限制,默认分配的内存只有几M(...
    99+
    2024-04-02
  • Android中ListView怎么使用
    这篇文章主要讲解了“Android中ListView怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android中ListView怎么使用”吧!一、具体思路1、创建Listview控...
    99+
    2023-06-22
  • Android的ListView怎么使用
    本篇内容主要讲解“Android的ListView怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android的ListView怎么使用”吧!在Android开发 中,经常会要用到水平水...
    99+
    2023-06-19
  • 怎么优化mui列表跳转到详情页
    这篇文章主要介绍“怎么优化mui列表跳转到详情页”,在日常操作中,相信很多人在怎么优化mui列表跳转到详情页问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么优化mui列表跳...
    99+
    2024-04-02
  • Android开发优化之Apk怎么优化
    本文小编为大家详细介绍“Android开发优化之Apk怎么优化”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android开发优化之Apk怎么优化”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。了解APK结构在讨...
    99+
    2023-06-30
  • android下拉列表怎么做
    要在Android应用中实现下拉列表,可以使用 Spinner 控件。Spinner 是一个下拉列表,用户可以从中选择一个选项。 以...
    99+
    2024-03-04
    android
  • 如何在android中利用listview实现一个列表展示效果
    今天就跟大家聊聊有关如何在android中利用listview实现一个列表展示效果,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。设置条目点击事件package com.it...
    99+
    2023-05-31
    android listview roi
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作