我一直在接触Flutter,我正在尝试构建一个非常简单的ToDo应用程序。它由一个TextField和一个Button(一个表单)组成,它位于屏幕顶部,允许用户将项目添加到文本字段下面的ListView。
我能够显示TextField和Button,我也能够显示ListView,但是当我尝试同时显示两者时,屏幕显示为空。
我错过了什么吗?我尝试将ListView显示到Column小部件中,但看起来它不起作用。
这是我没有表格的短代码:
import 'package:flutter/material.dart';
void main(){
runApp(MyApp());
}
class MyApp extends StatelessWidget{
@override
Widget build(BuildContext context){
return MaterialApp(
title: "Mon app",
home: Scaffold(
appBar: AppBar(
title: Text("My app")
),
body: Column(
children: <Widget>[
ListView(
children: <Widget>[
ListTile(
leading: Icon(Icons.map),
title: Text('Map'),
),
ListTile(
leading: Icon(Icons.photo_album),
title: Text('Album'),
),
ListTile(
leading: Icon(Icons.phone),
title: Text('Phone'),
),
],
)
])),
);
}
}
谢谢 !
是的。您应该在ListView周围使用Expanded
小部件。它的作用是扩展它的子节点(在本例中为ListView)以适应父节点上的最大可用空间,不包括其他小部件占用的空间。
然后,当您想在底部添加输入时,您可以将常规窗口小部件放在Column
内部,但在ListView
之外,因此列表将滚动并且TextField将始终保持在页面底部。
这是准备好底部输入的代码,但我建议您尝试仔细了解Columns,Rows和Expanded小部件的内容。
import 'package:flutter/material.dart';
void main(){
runApp(MyApp());
}
class MyApp extends StatelessWidget{
@override
Widget build(BuildContext context){
return MaterialApp(
title: "Mon app",
home: Scaffold(
appBar: AppBar(
title: Text("My app")
),
body: Column(
mainAxisSize: MainAxisSize.max,
children: <Widget>[
Expanded(
child: ListView(
children: <Widget>[
ListTile(
leading: Icon(Icons.map),
title: Text('Map'),
),
ListTile(
leading: Icon(Icons.photo_album),
title: Text('Album'),
),
ListTile(
leading: Icon(Icons.phone),
title: Text('Phone'),
),
],
),
),
Row(
children: <Widget>[
Expanded(
child: TextField(
decoration: InputDecoration(
hintText: "What to do?"
),
),
),
IconButton(
icon: Icon(Icons.send),
onPressed: (){
//do something
},
)
],
)
],
),
),
);
}
}
qazxsw poi的垂直视口被赋予了无限高度。用ListView
小部件包裹你的qazxsw poi
ListView