1

我是 Flutter 移动开发的新手。我有一个 dart 文件,它从我的本地主机获取 JSON 数据。现在我希望在 listView 中显示数据。

但我在日志中得到以下信息

I/flutter (23058):   EXCEPTION CAUGHT BY RENDERING LIBRARY 
I/flutter (23058): The following message was thrown during layout:
I/flutter (23058): A RenderFlex overflowed by 242 pixels on the right.

下面是我的代码来显示视图

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("Timeline"),
        backgroundColor: Colors.orange,
      ),
      body: ListView.builder(
        shrinkWrap: true,
        itemCount: data == null ? 0 : data.length,
        itemBuilder: (BuildContext context, int index) {
          return Container(
            child: Center(
              child: Row(
                children: <Widget>[
                  new Card(
                    child: new Container(
                      padding: EdgeInsets.all(8.0),
                      child: Column(
                        crossAxisAlignment: CrossAxisAlignment.start,
                        children: <Widget>[
                          new Text(
                            data[index]["text"],
                            softWrap: true,
                            style: new TextStyle(
                              fontFamily: 'Hind',
                              fontSize: 17.0, color: Colors.black87
                            )
                          ),
                        ],
                      ),
                    ),
                  ),
                ],
              ),
            ),
          );
        },
      ),
    );
  }

这是渲染画面的截图

4

1 回答 1

0

将您的卡片包装在展开的小部件中。

return Container(
            child: Center(
              child: Row(
                children: <Widget>[
                  Expanded(
                    child: new Card(
                      child: new Container(
                        padding: EdgeInsets.all(8.0),
                        child: Column(
                          crossAxisAlignment: CrossAxisAlignment.start,
                          children: <Widget>[
                            new Text(data[index],
                                softWrap: true,
                                //overflow: TextOverflow.ellipsis,
                                style: new TextStyle(
                                    fontFamily: 'Hind',
                                    fontSize: 17.0,
                                    color: Colors.black87)),
                          ],
                        ),
                      ),
                    ),
                  )
                ],
              ),
            ),
          );

截屏 在此处输入图像描述

于 2018-05-16T09:54:45.877 回答