Flutter如何輕松實現(xiàn)動態(tài)更新ListView淺析
前言
在 App 開發(fā)過程中,ListView 是 比較很常見的控件,用來處理 列表類的數(shù)據(jù)展示。當然 Flutter 也是支持的,由于 Flutter 是歸屬于聲明式 UI 編程,其處理起來要更加的簡單與便捷。
本文將通過一個極簡單的例子來說明一下 如何 實現(xiàn)動態(tài)更新數(shù)據(jù)。 在貼代碼之前,先介紹一些概念和內(nèi)容
數(shù)據(jù)集
final _names = ['Andrew', 'Bob', 'Charles']; int _counter = 0;
新的數(shù)據(jù)Item 'Someone($_counter)' 會被觸發(fā)加入到 _names 數(shù)組中。
觸發(fā)器
通常觸發(fā)加載數(shù)據(jù)是分頁數(shù)據(jù)加載完成,這里我們使用一個 FloatingActionButton 的點擊操作等價模擬。
floatingActionButton: FloatingActionButton(
onPressed: () {
setState(() {
_names.add('Someone($_counter)');
_counter ++;
});
},
tooltip: 'Add TimeStamp',
child: const Icon(Icons.add),展示視圖
Expanded(
child: ListView.builder(
itemCount: _names.length,
itemBuilder: (BuildContext context, int index) {
return Container(
width: double.infinity,
height: 50,
alignment: Alignment.center,
child: Text(_names[index]));
}),
),上述代碼
需要Expanded 包裹 ListView 確??臻g展示填充 使用 ListView.builder 方法實現(xiàn) ListView
總體來說,F(xiàn)lutter 中實現(xiàn) ListView 數(shù)據(jù)動態(tài)添加和展示,真的很便捷,少去了傳統(tǒng)UI 編程中顯式的 Adapter 等內(nèi)容,編碼效率提升不少。
完整代碼
import 'package:flutter/material.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
const MyHomePage({Key? key, required this.title}) : super(key: key);
final String title;
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
final _names = ['Andrew', 'Bob', 'Charles'];
int _counter = 0;
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: Column(
children: [
Expanded(
child: ListView.builder(
itemCount: _names.length,
itemBuilder: (BuildContext context, int index) {
return Container(
width: double.infinity,
height: 50,
alignment: Alignment.center,
child: Text(_names[index]));
}),
),
],
),
floatingActionButton: FloatingActionButton(
onPressed: () {
setState(() {
_names.add('Someone($_counter)');
_counter ++;
});
},
tooltip: 'Add TimeStamp',
child: const Icon(Icons.add),
), // This trailing comma makes auto-formatting nicer for build methods.
);
}
}以上。
總結(jié)
到此這篇關(guān)于Flutter如何輕松實現(xiàn)動態(tài)更新ListView的文章就介紹到這了,更多相關(guān)Flutter動態(tài)更新ListView內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
android判斷應(yīng)用是否已經(jīng)啟動的實例
這篇文章主要介紹了android判斷應(yīng)用是否已經(jīng)啟動的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
詳解基于Android的Appium+Python自動化腳本編寫
這篇文章主要介紹了詳解基于Android的Appium+Python自動化腳本編寫,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
Android開發(fā)之Fragment懶加載的幾種方式及性能對比
這篇文章主要介紹了Android開發(fā)之Fragment懶加載的幾種方式及性能對比的相關(guān)資料,具體詳細介紹需要的小伙伴可以參考下面文章內(nèi)容2022-05-05
Android基于google Zxing實現(xiàn)各類二維碼掃描效果
這篇文章主要介紹了Android基于google Zxing實現(xiàn)各類二維碼掃描效果的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-02-02
Android判斷后臺服務(wù)是否開啟的兩種方法實例詳解
這篇文章主要介紹了Android判斷后臺服務(wù)是否開啟的方法的相關(guān)資料,這里提供了兩種方法及實例,需要的朋友可以參考下2017-07-07
Android實現(xiàn)簡易計算器(可以實現(xiàn)連續(xù)計算)
這篇文章主要為大家詳細介紹了Android實現(xiàn)簡易計算器,可以實現(xiàn)連續(xù)計算,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-03-03

