Flutter中ListView 的使用示例

 更新时间:2018年07月27日 11:25:31   作者:刘斯龙  
这篇文章主要介绍了Flutter中ListView 的使用示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

这个小例子使用的是豆瓣 API 中 正在上映的电影 的开放接口,要实现的主要效果如下:

JSON 数据结构

Item 结构

Item 的结构是一个 Card 包含着一个 Row 然后这个 Row 里面左边是一个 Image ,右边是一个 Column

功能实现

  1. material 库
  2. Json 解析
  3. 网络请求
  4. 加载菊花

要实现上面四个功能,我们首先需要在 .dart 文件中引入如下代码

import 'dart:convert';
import 'package:http/http.dart' as http;
import 'package:flutter/material.dart';
import 'package:flutter/cupertino.dart';

网络请求

loadData() async {
 String loadRUL = "https://api.douban.com/v2/movie/in_theaters";
 http.Response response = await http.get(loadRUL);
 var result = json.decode(response.body);
 setState(() {
  title = result['title'];
  print('title: $title');
  subjects = result['subjects'];
 });
 }

ListView && 加载菊花

getBody() {
 if (subjects.length != 0) {
  return ListView.builder(
   itemCount: subjects.length,
   itemBuilder: (BuildContext context, int position) {
   return getItem(subjects[position]);
   });
 } else {
  // 加载菊花
  return CupertinoActivityIndicator();
 }
 }

Item编写

getItem(var subject) {
// 演员列表
 var avatars = List.generate(subject['casts'].length, (int index) =>
  Container(
   margin: EdgeInsets.only(left: index.toDouble() == 0.0 ? 0.0 : 16.0),

   child: CircleAvatar(
    backgroundColor: Colors.white10,
    backgroundImage: NetworkImage(
     subject['casts'][index]['avatars']['small']
    )
   ),
  ),
 );
 var row = Container(
  margin: EdgeInsets.all(4.0),
  child: Row(
  children: <Widget>[
   ClipRRect(
   borderRadius: BorderRadius.circular(4.0),
   child: Image.network(
    subject['images']['large'],
    width: 100.0, height: 150.0,
    fit: BoxFit.fill,
   ),
   ),
   Expanded(
    child: Container(
    margin: EdgeInsets.only(left: 8.0),
    height: 150.0,
    child: Column(
     crossAxisAlignment: CrossAxisAlignment.start,
     children: <Widget>[
//     电影名称
     Text(
      subject['title'],
      style: TextStyle(
      fontWeight: FontWeight.bold,
      fontSize: 20.0,
      ),
      maxLines: 1,
     ),
//     豆瓣评分
     Text(
      '豆瓣评分:${subject['rating']['average']}',
      style: TextStyle(
       fontSize: 16.0
      ),
     ),
//     类型
     Text(
      "类型:${subject['genres'].join("、")}"
     ),
//     导演
     Text(
      '导演:${subject['directors'][0]['name']}'
     ),
//     演员
     Container(
      margin: EdgeInsets.only(top: 8.0),
      child: Row(
      children: <Widget>[
       Text('主演:'),
       Row(
       children: avatars,
       )
      ],
      ),
     )
     ],
    ),
    )
   )
  ],
  ),
 );
 return Card(
  child: row,
 );
 }

主要代码就是上述这些... 效果图, 源码地址

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android开发实现录屏小功能

    Android开发实现录屏小功能

    这篇文章主要介绍了Android开发实现录屏小功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07
  • Flutter图片与文件选择器使用实例

    Flutter图片与文件选择器使用实例

    这篇文章主要为大家介绍了Flutter图片与文件选择器使用实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • Android 分享控件的实现代码

    Android 分享控件的实现代码

    这篇文章主要介绍了Android 分享控件的实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • Android中实现密码的隐藏和显示的示例

    Android中实现密码的隐藏和显示的示例

    本篇文章主要介绍了Android中实现密码的隐藏和显示的示例,非常具有实用价值,需要的朋友可以参考下
    2017-09-09
  • 详细分析Android-Zygote的启动过程

    详细分析Android-Zygote的启动过程

    在Android系统中,所有的应用程序进程以及系统服务进程SystemServer都是由Zygote进程孕育(fork)出来的,这也许就是为什么要把它称为Zygote(受精卵)的原因吧。由于Zygote进程在Android系统中有着如此重要的地位,本文将详细分析它的启动过程
    2021-06-06
  • 分析Android 11.0Settings源码之主界面加载

    分析Android 11.0Settings源码之主界面加载

    这篇文章主要介绍了分析Android 11.0Settings源码之主界面加载,对Android源码感兴趣的同学,可以着重看一下
    2021-04-04
  • Android中Activity的生命周期探讨

    Android中Activity的生命周期探讨

    这篇文章主要介绍了Android中Activity的生命周期探讨,本文同时讲解了销毁Activity、暂停与恢复、停止与重启Activity等内容,需要的朋友可以参考下
    2014-10-10
  • Android 使用Vitamio打造自己的万能播放器(1)——准备

    Android 使用Vitamio打造自己的万能播放器(1)——准备

    本文主要介绍Android Vitamio,在Android开发视频播放器的时候,大家经常会遇到系统版本和不同的Android手机不同导致开发的软件不能完美适用,这里给大家介绍个播放器插件可以适应所有Android设备
    2016-07-07
  • Android OkHttp的简单使用和封装详解

    Android OkHttp的简单使用和封装详解

    这篇文章主要介绍了Android OkHttp的简单使用和封装详解的相关资料,Android OKHttp的简单get、post的使用,再到它的封装,需要的朋友可以参考下
    2016-12-12
  • Flutter 中检测常用的命令详解

    Flutter 中检测常用的命令详解

    这篇文章主要介绍了Flutter 中检测常用的命令详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08

最新评论