Flutter小坑

Column或Row嵌套ListView或GridView#

LinearLayout是在Android原生开发中很常见的布局控件,在Flutter中我们可以使用Column代替纵向的线性布局,用Row代替横向的线性布局。

但是一旦我们的布局中有ListView或GridView,就可能会报如下的错误:

RenderBox was not laid out: RenderRepaintBoundary#d0a84 relayoutBoundary=up2 NEEDS-PAINT
'package:flutter/src/rendering/box.dart':
Failed assertion: line 1940 pos 12: 'hasSize'

意思是说,我们的ListView和GridView并没有一个明确的大小,Flutter不知道该如何在Column或Row中绘制它。

解决#

在ListView或GridView外面加一个Container来指定明确大小,或用Expanded让空间具有弹性空间,这个Expanded类似原生安卓LinearLayoutandroid:layout_weight属性,具体请查阅官方API。

// Old

Widget build(BuildContext context) {
    return Column(
        children: [
            GridView.count(
            // ...
            )
        ]
    );
}

// New

Widget build(BuildContext context) {
    return Column(
        children: [
            Expanded(child:GridView.count(
            // ...
            ))
        ]
    );
}

posted @   yudoge  阅读(384)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· winform 绘制太阳,地球,月球 运作规律
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示
主题色彩