2
                                   @_@

我正在考虑根据动态内容高度使 GridView 内的小部件具有不同的高度,并且这些小部件是内部带有扩展列的容器。但它随后给了我这个错误“不正确使用 ParentDataWidget”。

小部件如下所示:

Container(
      decoration: BoxDecoration(
        color: someColor,
        borderRadius: BorderRadius.circular(17),
      ),
      child: Expanded(
        child: Column(
          children: [
            ClipRRect(
              borderRadius: BorderRadius.circular(17),
              child: AspectRatio(
                aspectRatio: 5 / 3,
                child: Image.network(someImageUrl, fit: BoxFit.cover),
              ),
            ),
            SizedBox(height: 10),
            Text('Group name'),
            Text('Group desc'),
            SizedBox(height: 10),
            Expanded(
              child: Row(
                children: List.generate(
                  _group.popIds.length,
                  (_) => SizedBox(width: 50, height: 50),
                ),
              ),
            ),
            Text('Hello')
          ],
        ),
      ),
    );

这是包含这些小部件的屏幕:

Scaffold(
          body: Padding(
            padding:
                const EdgeInsets.only(left: 17.0, right: 17.0, top: 50),
            child: StaggeredGridView.countBuilder(
              crossAxisCount: 2,
              mainAxisSpacing: 10,
              crossAxisSpacing: 20,
              itemCount: 50,
              itemBuilder: (context, index) => GroupItem(),
              staggeredTileBuilder: (index) => StaggeredTile.fit(1),
            ),
          ),
        );

错误消息如下所示:

** ParentDataWidget 的使用不正确。

ParentDataWidget Expanded(flex: 1) 想要将 FlexParentData 类型的 ParentData 应用于 RenderObject,该 RenderObject 已设置为接受 ParentData 类型不兼容的 ParentData。**

有没有大神能帮我解决这个问题,我已经纠结了一天了!~@_@

4

1 回答 1

1

这是因为您在容器内使用 Expanded。Expanded 只能在 Column、Row 或 Flex 小部件内使用。

在您的第一个代码片段中,删除容器内的第一个 Expanded 小部件并包裹您的列,但您可以保留包裹行的第二个 Expanded 小部件,因为此展开的小部件在一列内,然后错误应该消失。

于 2021-03-24T22:41:37.030 回答