flutter Vertical viewport was gi
2020-04-22 本文已影响0人
晓函
完美解决flutter Vertical viewport was given unbounded height错误。
今天多层嵌套错误,终于解决(代码在末尾),花了2个小时百度了好久,都没解决(有说给listview加Expanded,有说加shrinkWrap,都不不符合我这里的实际,因为我这里还有EasyRefresh),最后自己一步一步测试,得出结论。
结论
Column里面嵌套Column、ListView、EasyRefresh等空间具有无限延展性等控件,每一层都需要用Expanded包裹,漏掉一层都不行。
记住哦,重要事情说三遍。
每一层都需要用Expanded包裹。
每一层都需要用Expanded包裹。
每一层都需要用Expanded包裹。
举例错误
Column(children:<Widget>[
SearchBar(),
EasyRefresh(
child:ListView()
)
]
)
这一段肯定会提示flutter Vertical viewport was given unbounded height
正确做法:
在EasyRefresh外面加上Expanded。
为什么ListView外面不用加了?因为EasyRefresh内部代码已经给ListView加过Expanded了。
Column(children:<Widget>[
SearchBar(),
Expanded(//加上
child:EasyRefresh(
child:ListView()
)
)
]
)
如果我们需要更复杂都多层嵌套,这里用多层Column+Column、EasyRefresh、ListView举例,那每层都需要加上才行。
//listview控件
widgetListView(){
return ListView.builder(
scrollDirection: Axis.vertical,
itemCount: 20,
itemBuilder: (context,i){
return Container(child: Text('test$i'),width: 100,height: 100,color: Colors.white,);
},
);
};
//多层嵌套实验Column、EasyRefresh、ListView
Column(//一层
children:<Widget>[
SearchBar(),
Expanded(child:
Column(//两层
children: <Widget>[
Expanded(
child:EasyRefresh(//三层
child:widgetListView()//四层(这层的Expanded在EasyRefresh内部实现了
)
)
],
)
)
]
);
只要每层可无限延展的控件外面都套上Expanded,允许他们最大值延展,那就没问题。
实测,按照上面加,不需要shrinkWrap: true, 也可以完美显示出来
image.png