【发布时间】:2020-10-31 20:29:42
【问题描述】:
当 scrollDirection 设置为垂直时,它会按预期工作。问题是当我将 section.axis 设置为 Axis.horizontal 以便 ListView 水平显示小部件时。
使用 Flexible 或 Expanded 小部件无法解决此问题,因为 ListView 的高度需要由列表中的小部件定义。
如您所见,shrinkWrap 也已启用。所以我不知道这里发生了什么,感谢您的帮助。
控制台说: 'constraints.hasBoundedHeight':不正确。 相关的导致错误的小部件是:ListView
class SectionWidget extends StatelessWidget {
final Section section;
const SectionWidget({@required this.section});
@override
Widget build(BuildContext context) {
return Column(
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Text(section.title),
ListView.separated(
shrinkWrap: true,
scrollDirection: section.axis,
physics: section.axis == Axis.vertical
? NeverScrollableScrollPhysics()
: null,
itemCount: section.itemList.length,
itemBuilder: (BuildContext context, int index) {
return Container(
height: 100,
width: 100,
color: Colors.red,
); // Just to test if it works
},
separatorBuilder: (BuildContext context, int index) {
double paddingBetween = 10;
if (section.axis == Axis.horizontal) {
return SizedBox(width: paddingBetween);
} else {
return SizedBox(height: paddingBetween);
}
},
),
],
);
}
}
【问题讨论】:
标签: android ios flutter listview horizontalscrollview