flutter Vertical viewport was given unbounded height

完美解决flutter Vertical viewport was given unbounded height错误。
今天多层嵌套错误,终于解决(代码在末尾),花了2个小时百度了好久,都没解决(有说给listview加Expanded,有说加shrinkWrap,都不不符合我这里的实际,因为我这里还有EasyRefresh),最后自己一步一步测试,得出结论。

结论

Column里面嵌套Column、ListView、EasyRefresh等空间具有无限延展性等控件,每一层都需要用Expanded包裹,漏掉一层都不行。
记住哦,重要事情说三遍。

每一层都需要用Expanded包裹。

每一层都需要用Expanded包裹。

每一层都需要用Expanded包裹。

举例错误

Column(children:[
  SearchBar(),
  EasyRefresh(
      child:ListView()
  )
]
)

这一段肯定会提示flutter Vertical viewport was given unbounded height

正确做法:

在EasyRefresh外面加上Expanded。
为什么ListView外面不用加了?因为EasyRefresh内部代码已经给ListView加过Expanded了。

Column(children:[
  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:[
        SearchBar(),
        Expanded(child:
        Column(//两层
          children: [
            Expanded(
              child:EasyRefresh(//三层
                  child:widgetListView()//四层(这层的Expanded在EasyRefresh内部实现了
                )
              )
            ],
          )
        )
      ]
    );

只要每层可无限延展的控件外面都套上Expanded,允许他们最大值延展,那就没问题。

实测,按照上面加,不需要shrinkWrap: true, 也可以完美显示出来

image.png

你可能感兴趣的:(flutter Vertical viewport was given unbounded height)