我正在创建一个动态列表,它创建如下图所示的布局。但在较小的屏幕上,我在“已发布”文本和删除图标的行中出现像素溢出。为了解决这个问题,我将它们包装在一个Wrap小部件中,以便图标可以移动到新行。但由于某种原因,Wrap 小部件没有扩展到完全可用的水平宽度。
我想定位“已发布”文本并删除带有Spacer()中间或仅对齐的图标spacebetween,但我无法在小部件Spacer()中定位 aWrap并且spaceBetween对齐没有效果,因为文本和图标之间没有可用空间。
SliverList(
delegate: SliverChildListDelegate(
[
for (var i = 0; i < children.length; i++)
Row(
crossAxisAlignment: CrossAxisAlignment.end,
children: [
Padding(
padding: const EdgeInsets.only(bottom: 10.0, left: 20.0),
child: Text(
children[i].issuanceDate,
),
),
Column(
//vertical line with round dot
),
Expanded(
child: Padding(
padding: const EdgeInsets.symmetric(vertical: 10.0),
child: Container(
padding: const EdgeInsets.symmetric(
vertical: 10.0, horizontal: 20.0),
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(6),
color: Colors.white,
boxShadow: [
BoxShadow(
color: (Colors.grey[200])!,
offset: const Offset(0, 8),
blurRadius: 8,
spreadRadius: 1.0,
)
],
),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Row(
children: [
Text(
children[i].credentialSubject.documentName,
style:
Theme.of(context).textTheme.bodyText1,
),
],
),
Wrap(
alignment: WrapAlignment.spaceBetween,
crossAxisAlignment: WrapCrossAlignment.center,
children: [ Text("${L.of(context).issued}${children[i].issuanceDate}",
style: Theme.of(context)
.textTheme
.bodyText2!
.copyWith(
color: Theme.of(context)
.colorScheme
.onBackground
.withOpacity(0.5)),
overflow: TextOverflow.ellipsis,
softWrap: true,
),
IconButton(
icon: Icon(
Icons.delete,
color: Theme.of(context).errorColor,
),
onPressed: () => print("delete $i"),
),
],
)
],
),
),
),
),
],
)
],
),
),
Run Code Online (Sandbox Code Playgroud)
Ale*_*sky 12
只需替换列交叉轴对齐即可拉伸:
...
child: Column(
crossAxisAlignment: CrossAxisAlignment.stretch, // !!!!!!! here
children: [
Row(
children: [
Text(
children[i].credentialSubject.documentName,
style:
Theme.of(context).textTheme.bodyText1,
),
...
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6082 次 |
| 最近记录: |