美文网首页flutter相关
flutter Vertical viewport was gi

flutter Vertical viewport was gi

作者: 晓函 | 来源:发表于2020-04-22 22:19 被阅读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

    相关文章

      网友评论

        本文标题:flutter Vertical viewport was gi

        本文链接:https://www.haomeiwen.com/subject/sapgihtx.html