一、Paddiing 组件
在 html 中常见的布局标签都有 padding 属性,但是 Flutter 中很多 Widget 是没有 padding 属 性。这个时候我们可以用 Padding 组件处理容器与子元素直接的间距。
属性 |
说明 |
padding |
padding 值,EdgeInsetss 设置填充值 |
child |
子组件 |
class PaddingWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Padding(
padding: EdgeInsets.fromLTRB(0, 0, 10, 0),
child: GridView.count(
crossAxisCount: 2,
childAspectRatio: 1.5,
children: [
Padding(
padding: EdgeInsets.fromLTRB(10, 10, 0, 0),
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-f214cb00231a4784.png',
fit: BoxFit.cover
)
),
Padding(
padding: EdgeInsets.fromLTRB(10, 10, 0, 0),
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-6f3e06b72ac3f406.png',
fit: BoxFit.cover
)
),
Padding(
padding: EdgeInsets.fromLTRB(10, 10, 0, 0),
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-2e006a5894bbab1c.png',
fit: BoxFit.cover
)
),
Padding(
padding: EdgeInsets.fromLTRB(10, 10, 0, 0),
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-7bd40d0269c75a40.png',
fit: BoxFit.cover
)
),
Padding(
padding: EdgeInsets.fromLTRB(10, 10, 0, 0),
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-684693c44f575ace.png',
fit: BoxFit.cover
)
),
Padding(
padding: EdgeInsets.fromLTRB(10, 10, 0, 0),
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-3b56e58df8c7e1c7.png',
fit: BoxFit.cover
)
),
Padding(
padding: EdgeInsets.fromLTRB(10, 10, 0, 0),
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-a3b61e6cf2426326.png',
fit: BoxFit.cover
)
),
]
)
);
}
}
二、 Row 水平布局组件
属性 |
说明 |
mainAxisAlignment |
主轴的排序方式 |
crossAxisAlignment |
次轴的排序方式 |
children |
组件子元素 |
class IconContainerWidget extends StatelessWidget {
double size;
IconData icon;
Color color;
IconContainerWidget(this.icon, {this.size, this.color = Colors.blue}) {
this.size = 32.0;
}
@override
Widget build(BuildContext context) {
return Container(
width: this.size + 60,
height: this.size + 60,
color: this.color,
child: Center(
child: Icon(this.icon, color: Colors.white, size: this.size)
)
);
}
}
class RowWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Container(
height: 700,
width: 500,
color: Colors.black12,
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
IconContainerWidget(Icons.home, color: Colors.red),
IconContainerWidget(Icons.search, color: Colors.green),
IconContainerWidget(Icons.send, color: Colors.orange)
]
)
);
}
}
三、Column 垂直布局组件
属性 |
说明 |
mainAxisAlignment |
主轴的排序方式 |
crossAxisAlignment |
次轴的排序方式 |
children |
组件子元素 |
class ColumnWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Container(
height: 700,
width: 500,
color: Colors.black12,
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
IconContainerWidget(Icons.home, color: Colors.red),
IconContainerWidget(Icons.search, color: Colors.green),
IconContainerWidget(Icons.send, color: Colors.orange)
]
)
);
}
}
四、Expanded 组件,类似 Web 中的 Flex 布局
属性 |
说明 |
felx |
元素站整个父 Row \ Column 的比例 |
child |
子元组 |
class ExpandedWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Padding(
padding: EdgeInsets.all(10),
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Expanded(
flex: 2,
child: IconContainerWidget(Icons.home)
),
SizedBox(width: 10),
Expanded(
flex: 3,
child: IconContainerWidget(Icons.search)
)
]
)
);
}
}
五、尝试实现下面的布局
class LayoutDemo extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Column(
children: [
Row(
children: [
Expanded(
child: Container(
height: 180,
color: Colors.black,
child: Text('你好Flutter'),
),
)
],
),
SizedBox(height: 10),
Row(
children: [
Expanded(
flex: 2,
child: Container(
height: 180,
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-f214cb00231a4784.png', fit: BoxFit.cover),
)
),
SizedBox(width: 10),
Expanded(
flex: 1,
child: Container(
height: 180,
child: ListView(
children: [
Container(
height: 85,
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-6f3e06b72ac3f406.png',fit: BoxFit.cover),
),
SizedBox(height: 10),
Container(
height: 85,
child: Image.network('https://upload-images.jianshu.io/upload_images/8863827-2e006a5894bbab1c.png',fit: BoxFit.cover),
)
],
)
)
),
],
)
],
);
}
}