【发布时间】:2019-03-04 12:43:53
【问题描述】:
我使用 Flutter,我想创建一个 ExpansionTile 列表,在同一个 Tile 中包含 2 个元素。
例如:
name :/.......White-Space....../ Snow.
firstname :/.......White-Space....../ John.
位置:/.......White-Space....../ Winterfell。
但我不知道这是否可能。(在互联网和文档上搜索后)
我尝试在儿童财产中使用 Column、Row、..,但没有任何效果。
有人有解决办法吗?
我的代码:
class Entry{
const Entry(this.title,[this.children = const <Entry>[]]);
final String title;
final List<Entry> children;
}
const List<Entry> data = <Entry> [
Entry(
' Profile',
<Entry>[
Entry('Jhon'),
Entry('Snow'),
Entry('Winterfell'),
],
),
...
class Collapsible extends StatelessWidget{
@override
Widget build(BuildContext context) {
return ListView.builder(
itemBuilder: (BuildContext context, int index) => EntryItem(data[index]),
itemCount: data.length,
);
}
}
class EntryItem extends StatelessWidget{
const EntryItem(this.entry);
final Entry entry;
Widget _buildTiles(Entry root){
if(root.children.isEmpty) return ListTile(title: Text(root.title));
return ExpansionTile(
backgroundColor: Colors.white30,
initiallyExpanded: true,
key: PageStorageKey<Entry>(root),
title: Center(child: Text(root.title),),
children: root.children.map(_buildTiles).toList()
);
}
@override
Widget build(BuildContext context) {
return _buildTiles(entry);
}
}
【问题讨论】:
标签: dart flutter flutter-layout