真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

FlutterListView怎么實(shí)現(xiàn)上拉加載更多下拉刷新的功能

本篇內(nèi)容主要講解“FlutterListView怎么實(shí)現(xiàn)上拉加載更多下拉刷新的功能”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“FlutterListView怎么實(shí)現(xiàn)上拉加載更多下拉刷新的功能”吧!

成都創(chuàng)新互聯(lián)IDC提供業(yè)務(wù):遂寧聯(lián)通機(jī)房,成都服務(wù)器租用,遂寧聯(lián)通機(jī)房,重慶服務(wù)器租用等四川省內(nèi)主機(jī)托管與主機(jī)租用業(yè)務(wù);數(shù)據(jù)中心含:雙線機(jī)房,BGP機(jī)房,電信機(jī)房,移動(dòng)機(jī)房,聯(lián)通機(jī)房。

下拉刷新

跟原生開(kāi)發(fā)一樣,下拉刷新在flutter里提供的有組件實(shí)現(xiàn) RefreshIndicator

一直不明白為啥組件中都提供下拉刷新,但就是沒(méi)有上拉加載??!

我這請(qǐng)求接口數(shù)據(jù)用的是 http 庫(kù),是個(gè)第三方的是需要安裝的 https://pub.dev/packages/http

用法如下

class MyHomePage extends StatefulWidget { MyHomePage({Key key}) : super(key: key); @override MyHomeWidget2 createState() => MyHomeWidget2();}class MyHomeWidget2 extends State { int page = 1; List data = new List(); var baseUrl = "https://cnodejs.org/api/v1"; @override void initState() { super.initState(); this._onRefresh(); } _fetchData() async { var response = await http.get(  '${this.baseUrl}/topics?mdrender=false&limit=10&page=${this.page}'); var json = await convert.jsonDecode(response.body); return json['data']; } Future _onRefresh() { data.clear(); this.page = 1; return _fetchData().then((data) {  setState(() => this.data.addAll(data)); }); } @override Widget build(BuildContext context) { return Scaffold(  body: RefreshIndicator( // 在ListView外包一層 RefreshIndicator 組件  onRefresh: _onRefresh, // 添加onRefresh方法  child: ListView.separated(   itemCount: this.data.length,   itemBuilder: (context, index) {   var _data = this.data[index];   return ListTile(    leading: Image.network(_data["author"]["avatar_url"]),    title: Text(_data["title"]),    subtitle: Text(_data["author"]["loginname"] +     " created at " +     new DateTime.now().toString()), // 為了看每次數(shù)據(jù)變動(dòng),這里直接取當(dāng)前時(shí)間    trailing: Icon(Icons.chevron_right));   },   separatorBuilder: (context, index) {   return Divider();   },  ) )); }}

上拉加載

上拉加載原理還是一樣的,給ListView加一個(gè) ScrollController 組件,然后通過(guò)事件監(jiān)聽(tīng)滾動(dòng)條的高度來(lái)顯示和隱藏加載更多的組件

先將加載更多的組件寫(xiě)好

Widget _loadMoreWidget() { return new Padding( padding: const EdgeInsets.all(15.0), // 外邊距 child: new Center(  child: new CircularProgressIndicator() ), );}

初始化一個(gè) ScrollController 組件,將其設(shè)置給 ListView 組件的 controller 屬性上

ScrollController _scrollController = new ScrollController();child: ListView.separated( controller: _scrollController, //...)

然后通過(guò)重寫(xiě) dispost() 方法來(lái)處理加載更多組件的釋放

@overridevoid dispose() { _scrollController.dispose(); super.dispose();}

最后通過(guò)數(shù)據(jù)源來(lái)控制界面渲染哪個(gè)組件,當(dāng)數(shù)據(jù)源循環(huán)渲染的 index 跟數(shù)據(jù)源一樣長(zhǎng)時(shí)(其實(shí)少1,下標(biāo)從0開(kāi)始的)就渲染加載更多組件,讓其顯示出來(lái),同時(shí)調(diào)用加載更多方法,獲取數(shù)據(jù),再通過(guò)state實(shí)現(xiàn)組件ui的更新

完整代碼如下

class MyHomePage extends StatefulWidget { MyHomePage({Key key}) : super(key: key); @override MyHomeWidget2 createState() => MyHomeWidget2();}class MyHomeWidget2 extends State { int page = 1; bool isLoadmore = false; List data = new List(); var baseUrl = "https://cnodejs.org/api/v1"; ScrollController _scrollController = new ScrollController(); @override void initState() { super.initState(); this._onRefresh(); _scrollController.addListener(() {  if (_scrollController.position.pixels == _scrollController.position.maxScrollExtent) {  _onLoadmore();  } }); } _fetchData() async { var response = await http.get(  '${this.baseUrl}/topics?mdrender=false&limit=10&page=${this.page}'); var json = await convert.jsonDecode(response.body); return json['data']; } Future _onRefresh() { data.clear(); this.page = 1; return _fetchData().then((data) {  setState(() => this.data.addAll(data)); }); } Future _onLoadmore() { this.page++; return _fetchData().then((data) {  setState((){  this.data.addAll(data);  isLoadmore = false;  }); }); } @override void dispose() { _scrollController.dispose(); super.dispose(); } Widget _loadMoreWidget() { return new Padding(  padding: const EdgeInsets.all(15.0),  child: new Center(  child: new CircularProgressIndicator()  ), ); } @override Widget build(BuildContext context) { return Scaffold(  body: RefreshIndicator(  onRefresh: _onRefresh,  child: ListView.separated(   controller: _scrollController,   itemCount: this.data.length,   itemBuilder: (context, index) {   if (index == data.length - 1) {    return _loadMoreWidget();   } else {    var _data = this.data[index];    return ListTile(     leading: Image.network(_data["author"]["avatar_url"]),     title: Text(_data["title"]),     subtitle: Text(_data["author"]["loginname"] +      " created at " +      new DateTime.now().toString()),     trailing: Icon(Icons.chevron_right));   }   },   separatorBuilder: (context, index) {   return Divider();   },  ) )); }}

到此,相信大家對(duì)“FlutterListView怎么實(shí)現(xiàn)上拉加載更多下拉刷新的功能”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!


本文標(biāo)題:FlutterListView怎么實(shí)現(xiàn)上拉加載更多下拉刷新的功能
文章位置:http://weahome.cn/article/jdheic.html

其他資訊

在線咨詢(xún)

微信咨詢(xún)

電話咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部