温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Flutter分页功能表格控件的用法

发布时间:2020-07-29 13:55:38 来源:亿速云 阅读:192 作者:小猪 栏目:移动开发

这篇文章主要讲解了Flutter分页功能表格控件的用法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。

PaginatedDataTable

PaginatedDataTable是一个带分页功能的DataTable,生成一批数据,项目中此一般通过服务器获取,定义model类:

class User {
 User(this.name, this.age, this.sex);

 final String name;
 final int age;
 final String sex;
}

生成数据:

List<User> _data = [];

@override
 void initState() {
 List.generate(100, (index) {
  _data.add(User('老孟$index', index % 50, index % 2 == 0 &#63; '男' : '女'));
 });
 super.initState();
 }

PaginatedDataTable的基础用法如下:

PaginatedDataTable(
 header: Text('header'),
 columns: [
 DataColumn(label: Text('姓名')),
 DataColumn(label: Text('性别')),
 DataColumn(label: Text('年龄')),
 ],
 source: MyDataTableSource(_data),
)

header表示表格顶部控件。

columns表示每一列的列头控件。

source表示数据源,需要继承DataTableSource,用法如下:

class MyDataTableSource extends DataTableSource {
 MyDataTableSource(this.data);

 final List<User> data;

 @override
 DataRow getRow(int index) {
 if (index >= data.length) {
  return null;
 }
 return DataRow.byIndex(
  index: index,
  cells: [
  DataCell(Text('${data[index].name}')),
  DataCell(Text('${data[index].sex}')),
  DataCell(Text('${data[index].age}')),
  ],
 );
 }

 @override
 int get selectedRowCount {
 return 0;
 }

 @override
 bool get isRowCountApproximate {
 return false;
 }

 @override
 int get rowCount {
 return data.length;
 }
}

效果如下:

Flutter分页功能表格控件的用法

getRow是根据index获取每一行的数据,通常使用DataRow.byIndex返回数据,cells表示每一个表格的数据,cells的数量需要与PaginatedDataTable中columns数量保持一致。

selectedRowCount是选中的行数,注意这里不是索引,是总共选中的行数。

isRowCountApproximate:如果isRowCountApproximate设置为true,行数将会无尽大,所以正常情况下isRowCountApproximate设置为false。

rowCount表示行数,如果isRowCountApproximate设置为true,此属性无效。

设置actions,显示在header的右端,用法如下:

PaginatedDataTable(
 header: Text('header'),
 actions: <Widget>[
 IconButton(icon: Icon(Icons.add),onPressed: (){},),
 IconButton(icon: Icon(Icons.delete),onPressed: (){},),
 ],
 ...
)

效果如下:

Flutter分页功能表格控件的用法

rowsPerPage表示每页显示的行数,默认10行,设置5行如下:

PaginatedDataTable(
 rowsPerPage: 5,
 ...
)

onRowsPerPageChanged不为null时,在左下角出现每页显示多少行数的选项,用法如下:

var _rowsPerPage = 5;
PaginatedDataTable(
 onRowsPerPageChanged: (v) {
 setState(() {
  _rowsPerPage = v;
 });
 },
 availableRowsPerPage: [5,10,15,16],
 rowsPerPage: _rowsPerPage,
 ...
)

效果如下:

Flutter分页功能表格控件的用法

点击出现availableRowsPerPage设置的数组,onRowsPerPageChanged为选择其中一项后回调,用于更新rowsPerPage属性。

显示的数据过多时,需要将PaginatedDataTable包裹在SingleChildScrollView中,滚动显示数据:

SingleChildScrollView(
 child: PaginatedDataTable()
)

onPageChanged是翻页时回调,返回当前页第一条数据的索引:

PaginatedDataTable(
 onPageChanged: (page){
 print('onPageChanged:$page');
 },

打印数据为:

flutter: onPageChanged:10
flutter: onPageChanged:20
flutter: onPageChanged:30
flutter: onPageChanged:40

排序

生序降序设置:

PaginatedDataTable(
 sortColumnIndex: 1,
 sortAscending: false,
 ...
)

效果如下:

Flutter分页功能表格控件的用法

生序降序的设置仅仅显示相应图标,数据并不会实际排序,对数据进行排序可以当用户点击表头时对数据按照本列数据进行排序,用法如下,

var _sortAscending = true;

_buildPaginatedDataTable() {
 return PaginatedDataTable(
 header: Text('header'),
 sortColumnIndex: 2,
 sortAscending: _sortAscending,
 columns: [
  DataColumn(label: Text('姓名')),
  DataColumn(label: Text('性别')),
  DataColumn(
   label: Text('年龄'),
   onSort: (index, sortAscending) {
   setState(() {
    _sortAscending = sortAscending;
    if (sortAscending) {
    _data.sort((a, b) => a.age.compareTo(b.age));
    } else {
    _data.sort((a, b) => b.age.compareTo(a.age));
    }
   });
   }),
 ],
 source: MyDataTableSource(_data),
 );
}

效果如下:

Flutter分页功能表格控件的用法

选中

可以在每一行的前面添加复选框,表示当前行是否选中,在User中添加是否选中属性,用法如下:

class User {
 User(this.name, this.age, this.sex, {this.selected = false});

 final String name;
 final int age;
 final String sex;
 bool selected;
}

添加勾选框:

@override
DataRow getRow(int index) {
 if (index >= data.length) {
 return null;
 }
 return DataRow.byIndex(
 index: index,
 selected: data[index].selected,
 onSelectChanged: (selected) {
  data[index].selected = selected;
  notifyListeners();
 },
 cells: [
  DataCell(
  Text('${data[index].name}'),
  ),
  DataCell(Text('${data[index].sex}')),
  DataCell(Text('${data[index].age}')),
 ],
 );
}

效果如下:

Flutter分页功能表格控件的用法

全选控制:

PaginatedDataTable(
 header: Text('header'),
 onSelectAll: (all) {
 setState(() {
  _data.forEach((f){
  f.selected = all;
  });
 });
 },

处理数据显示不全问题

当表格列比较多的时候,使用SingleChildScrollView包裹,显示不全时滚动显示,用法如下:

SingleChildScrollView(
 scrollDirection: Axis.horizontal,
 child: PaginatedDataTable()
)

效果如下:

Flutter分页功能表格控件的用法

看完上述内容,是不是对Flutter分页功能表格控件的用法有进一步的了解,如果还想学习更多内容,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI