Flutter实战技巧之-ListView不能懒加载导致的性能问题

前言

在原生android和ios上关于列表的组件默认都会支持复用和懒加载来提升性能和用户体验,在flutter中也不例外。flutter中提供的常用的列表组件例如ListView、GridView等也都支持复用和懒加载。在正常使用或者说不复杂的布局中,我们不需要去关心这些列表组件是否正常使用了复用和懒加载,但是在复杂(多种嵌套)或有大量数据交互的界面中,如果列表没有使用复用和懒加载那么带来的性能问题将是一个灾难。

懒加载测试

简单布局中测试

首先我们来看看简单布局下flutter中列表懒加载的表现:

import 'package:flutter/material.dart';

class ListPage extends StatefulWidget {
  @override
  State<StatefulWidget> createState() {
    return ListPageState();
  }
}

class ListPageState extends State<ListPage> {
  int count = 60;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: InkWell(
          child: Text('List Test'),
          onTap: () {},
        ),
      ),
      body: ListView.builder(
        itemBuilder: (context, index) {
          print('this is index = $index');
          return Container(
            height: 100,
            decoration: BoxDecoration(border: Border.all(color: Colors.purple, width: 1)),
            child: Center(child: Text('$index')),
          );
        },
        itemCount: 60,
      ),
    );
  }
}

GIF 2020-12-21 16-46-22.gif
在我们刚打开页面时,一共只加载了8个布局,而页面上我们能看见的只有5个,这个是因为列表会预加载超

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值