颤抖的滚动视图不滚动

时间:2019-03-02 09:59:55

标签: dart flutter

我有这个

  Widget _Project() {
return new ListView(
        children: <Widget>[
          Container(
            child: Card(
              color: _Cardcolor,
              child: Center(
                child: Text(
                  'Projects',
                  style: new TextStyle(
                    fontSize: 40.0,
                  ),
                ),
              ),
            ),
            margin: EdgeInsets.only(left: 50.0, right: 50.0, top: 10.0),
            height: 130.0,
            width: 15.0,
          ),
          Divider(
            height: 40,
          ),
          Container(
            child:  FutureBuilder<List<Project>>(
              future: fetchProjects(http.Client()),
              builder: (context, snapshot) {
                if (snapshot.hasError) print(snapshot.error);
                return snapshot.hasData
                    ? ProjectList(projects: snapshot.data)
                    : Center(child: CircularProgressIndicator());
              },
            ),
          )
        ],
    ) ;
  }

这是建造者

class ProjectList extends StatelessWidget {
  final List<Project> projects;
  ProjectList({Key key, this.projects}) : super(key: key);
  @override
  Widget build(BuildContext context) {
    return ListView.builder(
      shrinkWrap: true,
      itemCount: projects.length,
      itemBuilder: (context, index) {
        return Column(
          children: <Widget>[
            Container(
                color: Colors.white10,
                alignment: Alignment.center,
                child: Card(
                  child: Column(
                    mainAxisSize: MainAxisSize.min,
                    children: <Widget>[
                      ListTile(
                        title: Text(projects[index].ProjectId),
                        subtitle: Text(projects[index].ProjectId),
                      ),
                      ButtonTheme.bar(
                        // make buttons use the appropriate styles for cards
                        child: ButtonBar(
                          children: <Widget>[
                            FlatButton(
                              child: const Text('Open'),
                              onPressed: () {/* ... */},
                            ),
                          ],
                        ),
                      ),
                    ],
                  ),
                )),
          ],
        );
      },
    );
  }
}

因此,我正在使用卡片创建list。这是屏幕截图

enter image description here

数据来自json,并且显示正确。好吧,它显示不正确,因为我有5个,而我只显示了3个,这是因为滚动问题。当我缩小存储卡时,我的所有数据都会显示出来。

我已经尝试添加此行

 physics: const AlwaysScrollableScrollPhysics()

但仍然没有帮助,我现在被困住了

我该如何解决?我想念什么吗?

1 个答案:

答案 0 :(得分:1)

在您的课程中-ProjectList()-ListView.builder-添加-physics: ClampingScrollPhysics(),

Widget build(BuildContext context) {
    return ListView.builder(
      physics: ClampingScrollPhysics(),  // add this
      shrinkWrap: true,
      itemCount: projects.length,
      itemBuilder: (context, index) {
        return Column(
          children: <Widget>[ ...

更新: 要使card list仅滚动整个页面,请用Listview替换顶部的column

return Scaffold(
      body: Column(   // replace from listview
        children: <Widget>[
          SizedBox(height: 15.0,),
          Container(
            child: Card(
              //  color: _Cardcolor,
              child: Text(
                'Projects',
                style: new TextStyle(
                  fontSize: 44.0,
                ),
              ),
            ),
            margin: EdgeInsets.only(left: 50.0, right: 50.0, top: 15.0),
            height: 130.0,
           // width: 15.0,
          ),
          Divider(
            height: 40,
          ),
          Expanded( // add Expanded
            child: Container(
              child: ProjectList(
                projects: ['anmol', 'anmol', 'dummy', 'demo'],
              ),
//            child: FutureBuilder<List<Project>>(
//              future: fetchProjects(http.Client()),
//              builder: (context, snapshot) {
//                if (snapshot.hasError) print(snapshot.error);
//                return snapshot.hasData
//                    ? ProjectList(projects: snapshot.data)
//                    : Center(child: CircularProgressIndicator());
//              },
//            ),
            ),
          )
        ],
      ),