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

 

posted @ 2023-02-03 17:57  刘宏缔的架构森林  阅读(76)  评论(0编辑  收藏  举报