无论是用那种绑定数据的方式首先第一步都要添加数据,小菜测试基本样式包括 item 前置图标(leading)、标题文字(title)、后置图标(trailing),并设置了基本的 onTap() 方法;如下:
List strItems = [
'图标 -> keyboard', '图标 -> print',
'图标 -> router', '图标 -> pages',
'图标 -> zoom_out_map', '图标 -> zoom_out',
'图标 -> youtube_searched_for', '图标 -> wifi_tethering',
'图标 -> wifi_lock', '图标 -> widgets',
'图标 -> weekend', '图标 -> web',
'图标 -> accessible', '图标 -> ac_unit',
];
List icOnItems= [
new Icon(Icons.keyboard), new Icon(Icons.print),
new Icon(Icons.router), new Icon(Icons.pages),
new Icon(Icons.zoom_out_map), new Icon(Icons.zoom_out),
new Icon(Icons.youtube_searched_for), new Icon(Icons.wifi_tethering),
new Icon(Icons.wifi_lock), new Icon(Icons.widgets),
new Icon(Icons.weekend), new Icon(Icons.web),
new Icon(Icons.accessible), new Icon(Icons.ac_unit),
];
Widget buildListData(BuildContext context, String strItem, Icon iconItem) {
return new ListTile(
isThreeLine: false,
leading: iconItem,
title: new Text(strItem),
trailing: new Icon(Icons.keyboard_arrow_right),
onTap: () {
showDialog(
context: context,
builder: (BuildContext context) {
return new AlertDialog(
title: new Text(
'ListViewDemo',
style: new TextStyle(
color: Colors.black54,
fontSize: 18.0,
),
),
content: new Text('您选择的item内容为:$strItem'),
);
},
);
},
);
}
List _list = new List();
for (int i = 0; i ) {
_list.add(buildListData(context, strItems[i], iconItems[i]));
}
// 添加分割线
var divideList =
ListTile.divideTiles(context: context, tiles: _list).toList();
body: new Scrollbar(
child: new ListView(
// 添加ListView控件
// children: _list, // 无分割线
children: divideList, // 添加分割线
),
);
Tips: 如果需要设置分割线,需要对列表 item 添加处理,ListTile.divideTiles。
2. ListView.builder
小菜理解 builder 方式很像对话框类型逐个添加需要的属性;需要在 builder 中添加列表数据;而添加分割线的方式更让小菜体会到 Flutter 一切都是 widget 思想的重要性,如下:
// 没有分割线
child: new ListView.builder(
itemCount: iconItems.length, // 数据长度
itemBuilder: (context, item) {
return buildListData(context, strItems[item], iconItems[item]);
},
),
// 添加分割线
child: new ListView.builder(
itemCount: iconItems.length,
itemBuilder: (context, item) {
return new Container(
child: new Column(
children: [
buildListData(context, strItems[item], iconItems[item]),
new Divider()
],
),
);
},
),
3. ListView.separated
小菜对 separated 方式最大的理解是有直接的分隔符设置方式,对分隔符列表应用更实用;设置 separatorBuilder 属性即可;如下:
child: new ListView.separated(
itemCount: iconItems.length,
separatorBuilder: (BuildContext context, int index) => new Divider(), // 添加分割线
itemBuilder: (context, item) {
return buildListData(context, strItems[item], iconItems[item]);
},
),
4. ListView.custom
小菜暂时不对本加载方式做实例尝试,小菜理解 ListView.custom 更适合对 item 中含有子类 item,并对子类 item 的显隐性有更多操作时使用该方式更好;在以后的尝试中小菜会单独对这种方式进行测试整理。
主要源码
List _list = new List();
@override
Widget build(BuildContext context) {
for (int i = 0; i ) {
_list.add(buildListData(context, strItems[i], iconItems[i]));
}
var divideList =
ListTile.divideTiles(context: context, tiles: _list).toList();
return new Scaffold(
body: new Scrollbar(
// 默认方式 List
// child: new ListView(
// children: divideList, //添加ListView控件
// ),
// ListView.separated 方式
// child: new ListView.separated(
// itemCount: iconItems.length,
// separatorBuilder: (BuildContext context, int index) => new Divider(),
// itemBuilder: (context, item) {
// return buildListData(context, strItems[item], iconItems[item]);
// },
// ),
// ListView.builder 方式
child: new ListView.builder(
itemCount: iconItems.length,
itemBuilder: (context, item) {
return new Container(
child: new Column(
children: [
buildListData(context, strItems[item], iconItems[item]),
new Divider()
],
),
);
},
),
// child: new ListView.custom(
//
// ),
),
);
}
Tips: 列表中有一个属性很有意思:reverse 是否反转,如果设为 true,列表默认滑倒底部而且数据也是倒叙排列;若设为 false,则一切正常。其他很多属性也很有特点,小菜还没来得及深入探究。
GitHub Demo