Row和Column的父类,Flutter中最强大的布局方式。可容纳多个组件,可与Spacer、Expanded、Flexible组件联用进行灵活布局
相关组件
Flex的排布方向
<br />【children】 : 组件列表 【List<Widget>】<br />【direction】 : 方向 【Axis】<br />data:image/s3,"s3://crabby-images/7125a/7125aa20fd9802815d3f38299624e74da2811622" alt="image.png"
import 'package:flutter/material.dart';
class DirectionFlex extends StatelessWidget {
final redBox= Container(
color: Colors.red,
height: 30,
width: 40,
);
final blueBox= Container(
color: Colors.blue,
height: 20,
width: 30,
);
final greenBox= Container(
color: Colors.green,
height: 20,
width: 20,
);
@override
Widget build(BuildContext context) {
return Wrap(
children: Axis.values
.map((mode) => Column(children: <Widget>[
Container(
margin: EdgeInsets.all(5),
width: 160,
height: 80,
color: Colors.grey.withAlpha(33),
child: _buildItem(mode)),
Text(mode.toString().split('.')[1])
]))
.toList());
}
_buildItem(mode) => Flex(
direction: mode,
children: <Widget>[
blueBox, redBox, greenBox
],
);
}
Flex主轴对齐方式
<br />【mainAxisAlignment】 : 主轴对齐 【MainAxisAlignment】<br />data:image/s3,"s3://crabby-images/5d3aa/5d3aaff3cc739d52c15e3854db548666b603715f" alt="image.png"
import 'package:flutter/material.dart';
class MainAxisAlignmentFlex extends StatelessWidget {
final redBox= Container(
color: Colors.red,
height: 30,
width: 40,
);
final blueBox= Container(
color: Colors.blue,
height: 20,
width: 30,
);
final greenBox= Container(
color: Colors.green,
height: 20,
width: 20,
);
@override
Widget build(BuildContext context) {
return Wrap(
runSpacing: 5,
children: MainAxisAlignment.values
.map((mode) => Column(children: <Widget>[
Container(
margin: EdgeInsets.all(5),
width: 160,
height: 80,
color: Colors.grey.withAlpha(33),
child: _buildItem(mode)),
Text(mode.toString().split('.')[1])
]))
.toList());
}
_buildItem(mode) => Flex(
direction: Axis.horizontal,
mainAxisAlignment: mode,
children: <Widget>[
blueBox, redBox, greenBox
],
);
}
Flex交叉轴对齐方式
<br />【crossAxisAlignment】 : 交叉轴对齐 【CrossAxisAlignment】<br />data:image/s3,"s3://crabby-images/32083/32083e6c5d6f30644c30da9f4b0dda3a1338df66" alt="image.png"
import 'package:flutter/material.dart';
class CrossAxisAlignmentFlex extends StatelessWidget {
final redBox= Container(
color: Colors.red,
height: 30,
width: 40,
);
final blueBox= Container(
color: Colors.blue,
height: 20,
width: 30,
);
final greenBox= Container(
color: Colors.green,
height: 20,
width: 20,
);
@override
Widget build(BuildContext context) {
return Wrap(
runSpacing: 5,
children: CrossAxisAlignment.values
.map((mode) => Column(children: <Widget>[
Container(
margin: EdgeInsets.all(5),
width: 160,
height: 80,
color: Colors.grey.withAlpha(33),
child: _buildItem(mode)),
Text(mode.toString().split('.')[1])
]))
.toList());
}
_buildItem(mode) => Flex(
direction: Axis.horizontal,
crossAxisAlignment: mode,
textBaseline: TextBaseline.alphabetic,
children: <Widget>[
blueBox, redBox, greenBox
],
);
}
Flex垂直方向顺序
<br />【verticalDirection】 : 垂直方向顺序 【VerticalDirection】<br />data:image/s3,"s3://crabby-images/8bdc4/8bdc4ffcae13550bcb99e008b315fb4eed2ce998" alt="image.png"
import 'package:flutter/material.dart';
class VerticalDirectionFlex extends StatelessWidget {
final redBox= Container(
color: Colors.red,
height: 30,
width: 40,
);
final blueBox= Container(
color: Colors.blue,
height: 20,
width: 30,
);
final greenBox= Container(
color: Colors.green,
height: 20,
width: 20,
);
@override
Widget build(BuildContext context) {
return Wrap(
runSpacing: 5,
children: VerticalDirection.values
.map((mode) => Column(children: <Widget>[
Container(
margin: EdgeInsets.all(5),
width: 160,
height: 80,
color: Colors.grey.withAlpha(33),
child: _buildItem(mode)),
Text(mode.toString().split('.')[1])
]))
.toList());
}
_buildItem(mode) => Flex(
direction: Axis.vertical,
verticalDirection: mode,
children: <Widget>[
blueBox, redBox, greenBox
],
);
}
Flex水平方向顺序
<br />【textDirection】 : 水平方向顺序 【TextDirection】<br />data:image/s3,"s3://crabby-images/d70b4/d70b4a810bd556bc2b4ec33cae0ff00709dcbe2e" alt="image.png"
import 'package:flutter/material.dart';
class TextDirectionFlex extends StatelessWidget {
final redBox= Container(
color: Colors.red,
height: 30,
width: 40,
);
final blueBox= Container(
color: Colors.blue,
height: 20,
width: 30,
);
final greenBox= Container(
color: Colors.green,
height: 20,
width: 20,
);
@override
Widget build(BuildContext context) {
return Wrap(
runSpacing: 5,
children: TextDirection.values
.map((mode) => Column(children: <Widget>[
Container(
margin: EdgeInsets.all(5),
width: 160,
height: 80,
color: Colors.grey.withAlpha(33),
child: _buildItem(mode)),
Text(mode.toString().split('.')[1])
]))
.toList());
}
_buildItem(mode) => Flex(
direction: Axis.horizontal,
textDirection: mode,
children: <Widget>[
blueBox, redBox, greenBox
],
);
}