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,
 );
 }

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

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

相关文章

  • kotlin实现通知栏提醒功能示例代码

    kotlin实现通知栏提醒功能示例代码

    这篇文章主要给大家介绍了关于kotlin实现通知栏提醒功能的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用kotlin具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • Android 全局异常捕获实例详解

    Android 全局异常捕获实例详解

    这篇文章主要介绍了 Android 全局异常捕获实例详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • Android动画学习笔记之补间动画

    Android动画学习笔记之补间动画

    这篇文章主要为大家详细介绍了Android动画学习笔记之补间动画,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • Android动画之渐变动画(Tween Animation)详解 (渐变、缩放、位移、旋转)

    Android动画之渐变动画(Tween Animation)详解 (渐变、缩放、位移、旋转)

    这篇文章主要介绍了Android动画之渐变动画(Tween Animation)用法,结合实例形式详细分析了Android渐变动画Tween Animation实现渐变,缩放,位移,旋转等技巧,需要的朋友可以参考下
    2016-01-01
  • Android GridView中包含EditText的焦点重新获取方法

    Android GridView中包含EditText的焦点重新获取方法

    这篇文章主要介绍了Android GridView中包含EditText的焦点重新获取方法,实例分析了界面刷新时EditText重新获取焦点的技巧,需要的朋友可以参考下
    2016-03-03
  • Android判断wifi是5G还是2.4G

    Android判断wifi是5G还是2.4G

    这篇文章给大家分享android区分wifi是5G还是2.4G的方法,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下
    2016-12-12
  • Android编程简单实现九宫格示例

    Android编程简单实现九宫格示例

    这篇文章主要介绍了Android编程简单实现九宫格,结合具体实例形式分析了Android实现九宫格的具体步骤与相关布局、功能实现技巧,需要的朋友可以参考下
    2017-06-06
  • Android利用POI实现将图片插入到Excel

    Android利用POI实现将图片插入到Excel

    这篇文章主要为大家详细介绍了Android如何利用POI实现将图片插入到Excel,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-11-11
  • Android Button的基本用法详解及简单实例

    Android Button的基本用法详解及简单实例

    这篇文章主要介绍了Android Button的基本用法详解及简单实例的相关资料,需要的朋友可以参考下
    2017-02-02
  • Android Studio去除界面默认标题栏的方法

    Android Studio去除界面默认标题栏的方法

    这篇文章主要介绍了Android Studio去除界面默认标题栏的方法,本文通过图文并茂的形式给大家介绍的非常详细,对大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2007-09-09

最新评论