flutter:使用listview之一(flutter 3.7.0)
一,flutter代码
1,page/list.dart
import 'package:flutter/material.dart'; import 'package:dio/dio.dart'; import 'package:demolist/model/list_goods.dart'; import 'dart:convert'; import 'package:flutter/widgets.dart'; class ItemList extends StatefulWidget { @override _MyList createState()=> _MyList(); } //封装的动态页面类 class _MyList extends State<ItemList>{ static const double ITEM_HEIGHT = 100; static const double TITLE_HEIGHT = 80; static const double MARGIN_SIZE = 10; ScrollController _scrollController = ScrollController(); //listview 的控制器 //存放数据 List<ListGoods> _listData=[]; //当前第几页 int _currentPage = 0; int _total = 1; //http方式获取数据 Future<Null> getHttp() async{ String url = 'http://api.lhdtest.com/goods/list?page='+_currentPage.toString(); print(url); try { var response = await Dio().get(url); print(response); //处理json到类中 var resoMap=json.decode(response.toString()); _total = resoMap['data']['total']; print("total:"+_total.toString()); for (int i = 0; i < (resoMap['data']['list'].length); i++) { print("i:"+i.toString()); var itemOne = resoMap['data']['list'][i]; print(itemOne); ListGoods goodsOne = new ListGoods(itemOne['name'],itemOne['desc'], itemOne['id']); _listData.add(goodsOne); } setState(() { }); } catch (e) { print(e); } } @override void initState() { // TODO: implement initState super.initState(); getHttp(); } //构造list的item Widget _buildRow(int index) { //非最后一行 return Container( margin: EdgeInsets.all(0), color: Colors.orange, child: Row( crossAxisAlignment: CrossAxisAlignment.start, children:[ _imageWrapper("https://images.taboola.com.cn/taboola/image/fetch/f_jpg%2Cq_auto%2Ch_350%2Cw_420%2Cc_fill%2Cg_faces:auto%2Ce_sharpen/http%3A//cdn.taboola.com/libtrc/static/thumbnails/7dc5d37f2949e30163c870e0e5585592.jpg"), Expanded( child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ _titleWrapper(context, _listData[index].name), _descWrapper(context, _listData[index].desc), _viewCountWrapper(_listData[index].id.toString(),_listData[index].id), ], ), ) ] ), ); } Widget _descWrapper(BuildContext context, String text) { return Container( height: 60, margin: EdgeInsets.fromLTRB(MARGIN_SIZE, 0, 0, 0), decoration: new BoxDecoration( color: Colors.yellow, ), child: Text( text, maxLines: 2, overflow: TextOverflow.ellipsis, style: Theme.of(context).textTheme.headline6, ), ); } Widget _titleWrapper(BuildContext context, String text) { return Container( height: 60, margin: EdgeInsets.fromLTRB(MARGIN_SIZE, 0, 0, 0), decoration: new BoxDecoration( color: Colors.red, ), child: Text( text, maxLines: 2, overflow: TextOverflow.ellipsis, style: Theme.of(context).textTheme.headline6, ), ); } Widget _viewCountWrapper(String text,int viewCount) { return Container( margin: EdgeInsets.fromLTRB(MARGIN_SIZE, 0, 0, 0), height: ITEM_HEIGHT - TITLE_HEIGHT, decoration: new BoxDecoration( color: Colors.blue, ), child: Row(children: [ Icon( Icons.remove_red_eye_outlined, size: 14.0, color: Colors.grey, ), SizedBox(width: 5), Text( viewCount.toString(), style: TextStyle(color: Colors.grey, fontSize: 14.0), ), ]), ); } Widget _imageWrapper(String imageUrl) { return SizedBox( width: 150, height: ITEM_HEIGHT, child: Image.network(imageUrl), ); } @override void dispose() { _scrollController.dispose(); super.dispose(); } @override Widget build(BuildContext context) { var content; if (_listData.length == 0) { content = new Center( // 可选参数 child: child: new CircularProgressIndicator(), ); } else { content = _contentList(); } return Scaffold( appBar: AppBar(title: Text('这是首页'),), body: content, ); } Widget _contentList() { return ListView.builder( itemCount: _listData.length, itemBuilder: (BuildContext context, int index) { return getItem(context,index); }, controller: _scrollController, ); } Widget getItem(BuildContext context,int index) { return new GestureDetector( child:_buildRow(index), ); } }
2,model/list_goods.dart
class ListGoods { String name; String desc; int id; ListGoods(this.name,this.desc, this.id) {} ListGoods.fromJson(Map<String, dynamic>json) :name=json["name"], desc = json["desc"], id = json["id"]; Map<String, dynamic> toJson() { return { "name": name, "desc": desc, "id": id }; } }
3,接口返回的数据格式:
说明:刘宏缔的架构森林是一个专注架构的博客,
网站:https://blog.imgtouch.com
原文: https://blog.imgtouch.com/index.php/2023/06/04/flutter-shi-yong-listview-zhi-yi-flutter-3-7/
对应的源码可以访问这里获取: https://github.com/liuhongdi/
或: https://gitee.com/liuhongdi
说明:作者:刘宏缔 邮箱: 371125307@qq.com
二,测试效果
三,查看flutter的版本:
liuhongdi@liuhongdideMBP ~ % flutter --version Flutter 3.7.0 • channel stable • https://github.com/flutter/flutter.git Framework • revision b06b8b2710 (10 days ago) • 2023-01-23 16:55:55 -0800 Engine • revision b24591ed32 Tools • Dart 2.19.0 • DevTools 2.20.1