欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Flutter 分頁功能表格控件詳細(xì)解析

 更新時間:2020年04月29日 08:42:43   作者:老孟Flutter  
這篇文章主要介紹了Flutter 分頁功能表格控件詳細(xì)解析,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

前2天有讀者問到是否有帶分頁功能的表格控件,今天分頁功能的表格控件詳細(xì)解析。

PaginatedDataTable

PaginatedDataTable是一個帶分頁功能的DataTable,生成一批數(shù)據(jù),項目中此一般通過服務(wù)器獲取,定義model類:

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

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

生成數(shù)據(jù):

List<User> _data = [];

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

PaginatedDataTable的基礎(chǔ)用法如下:

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

header表示表格頂部控件。

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

source表示數(shù)據(jù)源,需要繼承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;
 }
}

效果如下:

getRow是根據(jù)index獲取每一行的數(shù)據(jù),通常使用DataRow.byIndex返回數(shù)據(jù),cells表示每一個表格的數(shù)據(jù),cells的數(shù)量需要與PaginatedDataTable中columns數(shù)量保持一致。

selectedRowCount是選中的行數(shù),注意這里不是索引,是總共選中的行數(shù)。

isRowCountApproximate:如果isRowCountApproximate設(shè)置為true,行數(shù)將會無盡大,所以正常情況下isRowCountApproximate設(shè)置為false。

rowCount表示行數(shù),如果isRowCountApproximate設(shè)置為true,此屬性無效。

設(shè)置actions,顯示在header的右端,用法如下:

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

效果如下:

rowsPerPage表示每頁顯示的行數(shù),默認(rèn)10行,設(shè)置5行如下:

PaginatedDataTable(
 rowsPerPage: 5,
 ...
)

onRowsPerPageChanged不為null時,在左下角出現(xiàn)每頁顯示多少行數(shù)的選項,用法如下:

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

效果如下:

點(diǎn)擊出現(xiàn)availableRowsPerPage設(shè)置的數(shù)組,onRowsPerPageChanged為選擇其中一項后回調(diào),用于更新rowsPerPage屬性。

顯示的數(shù)據(jù)過多時,需要將PaginatedDataTable包裹在SingleChildScrollView中,滾動顯示數(shù)據(jù):

SingleChildScrollView(
 child: PaginatedDataTable()
)

onPageChanged是翻頁時回調(diào),返回當(dāng)前頁第一條數(shù)據(jù)的索引:

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

打印數(shù)據(jù)為:

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

排序

生序降序設(shè)置:

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

效果如下:

生序降序的設(shè)置僅僅顯示相應(yīng)圖標(biāo),數(shù)據(jù)并不會實際排序,對數(shù)據(jù)進(jìn)行排序可以當(dāng)用戶點(diǎn)擊表頭時對數(shù)據(jù)按照本列數(shù)據(jù)進(jìn)行排序,用法如下,

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),
 );
}

效果如下:

選中

可以在每一行的前面添加復(fù)選框,表示當(dāng)前行是否選中,在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}')),
 ],
 );
}

效果如下:

全選控制:

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

處理數(shù)據(jù)顯示不全問題

當(dāng)表格列比較多的時候,使用SingleChildScrollView包裹,顯示不全時滾動顯示,用法如下:

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

效果如下:

交流

老孟Flutter博客地址(近200個控件用法):http://laomengit.com

到此這篇關(guān)于Flutter 分頁功能表格控件詳細(xì)解析的文章就介紹到這了,更多相關(guān)Flutter 分頁功能表格控件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Android基于OpenGL在GLSurfaceView上繪制三角形及使用投影和相機(jī)視圖方法示例

    Android基于OpenGL在GLSurfaceView上繪制三角形及使用投影和相機(jī)視圖方法示例

    這篇文章主要介紹了Android基于OpenGL在GLSurfaceView上繪制三角形及使用投影和相機(jī)視圖方法,結(jié)合實例形式分析了Android基于OpenGL的圖形繪制技巧,需要的朋友可以參考下
    2016-10-10
  • Android實現(xiàn)底部彈窗效果

    Android實現(xiàn)底部彈窗效果

    這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)簡單的底部彈窗效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 詳解Android中BroadCastReceiver組件

    詳解Android中BroadCastReceiver組件

    這篇文章主要為大家詳細(xì)介紹了Android中BroadCastReceiver組件,Broadcast Receiver是Android的五大組件之一,使用頻率也很高,用于異步接收廣播Intent,感興趣的小伙伴們可以參考一下
    2016-02-02
  • JankMan-極致的卡頓分析系統(tǒng)

    JankMan-極致的卡頓分析系統(tǒng)

    這篇文章主要為大家介紹了JankMan-極致的卡頓分析系統(tǒng)使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • Android實現(xiàn)簡單的加載進(jìn)度條

    Android實現(xiàn)簡單的加載進(jìn)度條

    這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)簡單的加載進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • 你該知道的Gradle配置知識總結(jié)

    你該知道的Gradle配置知識總結(jié)

    這篇文章主要給大家介紹了關(guān)于Gradle配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對各位Android開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考學(xué)習(xí),下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-10-10
  • Android入門之在SharedPreference中使用加密

    Android入門之在SharedPreference中使用加密

    這篇文章主要為大家詳細(xì)介紹了Android如何使在SharedPreference中使用加密,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Android有一定的幫助,需要的可以參考一下
    2022-12-12
  • Flutter 狀態(tài)管理的實現(xiàn)

    Flutter 狀態(tài)管理的實現(xiàn)

    這篇文章主要介紹了Flutter 狀態(tài)管理的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • android實現(xiàn)添加耳機(jī)狀態(tài)圖標(biāo)的方法

    android實現(xiàn)添加耳機(jī)狀態(tài)圖標(biāo)的方法

    這篇文章主要介紹了android實現(xiàn)添加耳機(jī)狀態(tài)圖標(biāo)的方法,較為詳細(xì)的分析了Android實現(xiàn)添加耳機(jī)圖標(biāo)的原理與相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • Android自定義控件實現(xiàn)圓形進(jìn)度CircleProgressBar

    Android自定義控件實現(xiàn)圓形進(jìn)度CircleProgressBar

    這篇文章主要為大家詳細(xì)介紹了Android自定義控件實現(xiàn)圓形進(jìn)度CircleProgressBar,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05

最新評論