首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Flutter开发-可滚动组件

当列表滚动到具体的index位置时,会调用该构建器构建列表项。 itemCount:列表项的数量,如果为null,则为无限列表。...上面我们介绍的GridView都需要一个widget数组作为其子元素,这些方式都会提前将所有子widget都构建好,所以只适用于子widget数量比较少时,当子widget比较多时,我们可以通过GridView.builder...GridView.builder 必须指定的参数有两个: GridView.builder( ......); }); }); } } _retrieveIcons():在此方法中我们通过Future.delayed来模拟从异步数据源获取数据,每次获取数据需要200毫秒,获取成功后将新数据添加到...实际上Sliver版的可滚动组件和非Sliver版的可滚动组件最大的区别就是前者不包含滚动模型(自身不能再滚动),而后者包含滚动模型 ,也正因如此,CustomScrollView才可以将多个Sliver

4.5K20

Flutter | 滚动组件,ListView,GridVIew等

可滚动组件 当组件内容超过当前显示视口(ViewPort)时,如果没有特殊处理,Flutter 就会提示 Overflow 错误,为此,Flutter 提供了多种可滚动组件,用于显示列表和长布局; 可滚动组件都直接或间接的包含一个...800 像素,但是 ViewPort 任然是 800 像素 基于 Sliver 的延时构建 通常可滚动的组件会非常多,占用的总高度也会非常大;如果一次性将子组件全部构建出将会非常昂贵!...itemCount:列表项的数量,如果为 null ,则代表无限列表 可滚动组件的构造函数如果需要一个列表项 Builder ,那么通过构造函数构建的通常就是支持 Sliver 的懒加载模型的,反正则不支持...GridView.builder 必须指定的构造参数有两个: GridView.builder( ......,这个时候就可以使用 CustomScrollView,他相当于一个胶水,将这些彼此独立的可滚动组件粘起来。

8.7K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Flutter可滑动组件

    在Flutter中,我们也有对应的列表Widget,就是ListView。 注意:在Flutter里面想要实现滑动效果,都需要在组件外部包裹滚动的视图。...当列表滚动到具体的index位置时,会调用该构建器构建列表项。 itemCount:列表项的数量,如果为null,则为无限列表。...,同时将每个item的高度强行设置为50。...Flutter中有一个可以完成这样滚动效果的Widget:CustomScrollView,其成员变量slivers可以接收一组Sliver,从而达到统一管理多个滚动视图的目的。...比如视图滚动到底部时,我们可能希望做上拉加载更多;比如滚动到一定位置时显示一个回到顶部的按钮,点击回到顶部的按钮,回到顶部;比如监听滚动什么时候开始,什么时候结束; 在Flutter中监听滚动相关的内容由两部分组成

    7.2K30

    GridView滚动列表的顶级用法【flutter20个实例之二】

    一、老套路,先看样式 文章底部源码,是左侧样式,右侧是我实际开发中的展示 ? ? 二、讲解(后附源码) 1.这里主要是用到GridView 组件 GridView是一个可滚动的,2D数组控件。...:Android Studio对flutter的一些快捷键 5.当然通过children的方式加载组件并不是个好方式 GridView提供了一些快速构建的方法 ,记住以下常用的两个就行 GridView.builder...80, color: Colors.primaries[i % Colors.primaries.length], ); }), ) 三、源码 import 'package:flutter...EdgeInsets.all(8.0), child: getItem(), )); } //列表 Widget getItem() { return GridView.builder...(竖向滚动) mainAxisSpacing: 4 //两行之间的距离(竖向滚动) ), itemBuilder: (context, index)

    2K20

    《Flutter》-- 6.高级组件

    参阅书籍: 《Flutter跨平台开发入门与实践》-- 向治洪(著) 6. 高级组件 6.1 可滚动组件 对于列表和长布局的显示溢出问题,可以使用Flutter提供的可滚动组件来处理。...如果一个可滚动组件支持Sliver,那么该可滚动组件可以将子组件分成多个Sliver,只有当Sliver出现在视图窗口时才会去构建它,从而提高渲染的性能。...,可以包含多个子组件,而且可以将这些子组件包裹起来实现一致的滚动效果。...如果为null,则列表为无限列表。...5个: 1)GridView():默认构造函数,适用于元素个数有限的场景,会一次性全部渲染children属性中的子元素组件; 2)GridView.builder():适用于构建大量或无限长的列表,它只会构建那些可见的组件

    10.7K20

    【Flutter】FutureBuilder 异步编程 ( FutureBuilder 构造方法 | AsyncSnapshot 异步计算 )

    文章目录 一、FutureBuilder 简介 二、FutureBuilder 构造方法 三、AsyncSnapshot 异步计算 四、相关资源 一、FutureBuilder 简介 ---- FutureBuilder...将 异步操作 与 异步 UI 更新 结合在一起 ; 它可以将 异步操作 的结果 , 异步的 更新到 UI 界面中 ; 异步操作结果 : 网络请求 , 数据库读取 , 等耗时操作 得到的结果 ; 二、FutureBuilder... builder }) FutureBuilder 构造方法参数解析 : Future future : 与异步操作相关的异步计算 ; /// The asynchronous computation...上的 Flutter 开源示例 : https://download.csdn.net/download/han1202012/15989510 Flutter 实战电子书 : https://book.flutterchina.club.../animations/ 博客源码下载 : GitHub 地址 : https://github.com/han1202012/flutter_http( 随博客进度一直更新 , 有可能没有本博客的源码

    92320

    Flutter异步编程Future与FutureBuilder的实用技巧

    在这篇文章中,将向大家分享异步编程Future与FutureBuilder的一些实用知识和技巧,首先会带着大家认识什么是Future?、Future的常见用法?、以及什么是FutureBuilder?...,以及FutureBuilder常见的用法?等。 在大家Flutter开发环境过程中遇到无法解决的问题可以在课程问答区进行提问,课程老师会对你进行辅导和帮助; 目录 什么是Future?...练一练 什么是FutureBuilder? FutureBuilder是一个将异步操作和异步UI更新结合在一起的类,通过它我们可以将网络请求,数据库读取等的结果更新的页面上。...现在我们可以看到使用FutureBuilder的基本模式。 在创建新的FutureBuilder对象时,我们将Future对象作为要处理的异步计算传递。...https://flutter-academy.com/async-in-flutter-futurebuilder/ FutureBuilder的使用?

    2.3K10

    【Flutter】Future 与 FutureBuilder 异步编程代码示例 ( FutureBuilder 构造函数设置 | 处理 Flutter 中文乱码 | 完整代码示例 )

    文章目录 一、FutureBuilder 简介 二、处理 Flutter 中的中文乱码 三、完整代码示例 四、相关资源 一、FutureBuilder 简介 ---- FutureBuilder 本质是组件...: FutureBuilder 构造好以后 , 会自动执行异步操作 , 并返回 Widget 组件 , 因此 FutureBuilder 也是一个组件 , 在不同的状态下显示不同样式的组件 ; FutureBuilder...泛型设置 : FutureBuilder 的泛型 , 表示异步调用得到的 Future 的泛型 , 也就是返回结果的格式 ; FutureBuilder 表示异步调用 Future...> 类型的方法 , 可以直接设置给 FutureBuilder 构造函数作为参数 ; /// 调用 Http Get 方法 , 获取服务器的 json 数据 Future<CommonModel...utf8decoder = Utf8Decoder(); 调用解码器的 convert 方法 , 传入原始的二进制数据 , 注意是字节数组类型的数据 ; /// 将二进制 Byte 数据以 UTF

    2.4K20

    flutter系列之:flutter中常用的GridView layout详解

    简介 GridView是一个网格化的布局,如果在填充的过程中子组件超出了展示的范围的时候,那么GridView会自动滚动。 因为这个滚动的特性,所以GridView是一个非常好用的Widget。...GridView.builder,这个构造函数和默认的构造函数的区别在于childrenDelegate的实现不同,我们来看下GridView.builder中childrenDelegate的实现:...举个例子,如果GirdView是竖向滚动的,并且它的width是400 pixels,如果这个时候maxCrossAxisExtent被设置为120,那么一行只能有三列。..., (i) => Container( child: Image.asset('images/head.jpg'))); } 最后将构造的GridViewApp放到Scaffold...总结 GridView是一个我们在日常工作中经常会使用的组件,希望大家能够熟练掌握。 本文的例子:https://github.com/ddean2009/learn-flutter.git

    92320

    FLutter异步加载组件FutureBuilder

    在flutter中我们可以在initState中发起异步请求,然后将请求结果赋值给data,并setState刷新页面,在build中可以这样实现 if(data == null){ return..._LoadingWidget() } else{ return ... } 实际上flutter提供了一个FutureBuilder专门来处理需要异步的组件,下面是一个简单的示例: var _...,可能仅仅是更新页面上的一个文案,这样就会造成不必要的浪费和消耗,我们要尽量避免,所以就需要防止FutureBuilder重绘。...所以我们只要提前将异步任务的函数赋值给一个变量,然后在FutureBuilder中使用这个变量即可,如下: var _mFuture; @override void initState()...( future: _mFuture, ... ) 这样重绘的时候因为是同一个对象,所以FutureBuilder不会重绘,减少了不必要的资源损耗。

    2.2K30

    flutter仿BOSS直聘(二),大前端技术实现

    项目简介 记得上一篇的写作时间还在2018年2月份,已经很久没更新了,而flutter的版本更新了好几次,自flutter 1.0正式版推出之后,一直有打算把之前的项目重写一下,因为flutter本身更新了许多新特性...这里就不过多占用篇幅了,本文主要还是讲flutter,对前端感兴趣的会另外分享相关技术话题。 flutter端: 项目中使用以下组件,请记住一句咒语:flutter一切皆组件。...Container, Row, Column, Flex, ListView, CustomListView, Wrap, Padding, Center, Future, FutureBuilder,...大家都知道,flexibleSpace里的CollapseMode.parallax属性可以在屏幕滚动时把title移动到appBar里,可实际上,布局是定制的,实现不了官方的那种效果,于是通过监听ScrollController...并计算滚动位置的方式修改state属性让appBar的title根据滚动位置显示隐藏。

    1.9K20

    Flutter 刷新页面:通过下拉刷新提升用户体验

    Flutter 中的 RefreshIndicator 被设计来配合 ListView 或者其他滚动的挂件使用,通过可视化的反馈和平缓的更新动作来提升用户体验。...它允许我们将应用的状态通过 widget tree 进行传递。...RefreshIndicator 挂件应该覆盖在需要刷新的可滚动的内容上。还有很重要的一点需要注意,RefreshIndicator 只在垂直可滚动的 child 上才可工作,。...RefreshIndicator 将保持转动直到 Future 被解决,这将发生在新数据准备好并更新了 UI。...当处理复杂的数据和状态时,考虑使用流 streams 或者 FutureBUilder 挂件来更新 UI,当新数据反应可用时。这保证在应用程序当前状态, UI 还是同步的,即使数据被拉取和更新。

    33510

    flutter系列之:flutter中常用的GridView layout详解

    简介GridView是一个网格化的布局,如果在填充的过程中子组件超出了展示的范围的时候,那么GridView会自动滚动。因为这个滚动的特性,所以GridView是一个非常好用的Widget。...GridView.builder,这个构造函数和默认的构造函数的区别在于childrenDelegate的实现不同,我们来看下GridView.builder中childrenDelegate的实现:childrenDelegate...举个例子,如果GirdView是竖向滚动的,并且它的width是400 pixels,如果这个时候maxCrossAxisExtent被设置为120,那么一行只能有三列。..., (i) => Container( child: Image.asset('images/head.jpg'))); }最后将构造的GridViewApp放到Scaffold的body...总结GridView是一个我们在日常工作中经常会使用的组件,希望大家能够熟练掌握。本文的例子:https://github.com/ddean2009/learn-flutter.git

    74520

    Flutter跨平台移动端开发丨SingleChildScrollView、ListView......

    ScrollController的主要作用是控制滚动位置和监听滚动事件 child:子元素 import 'package:flutter/material.dart'; /** * @des Scroll...中的 id) scrollDirection:滚动方向,默认是垂直 reverse:是否按照阅读方向相反的方向滑动。...指定 itemExtent 的值比让子元素决定自身长度在绘制时更高效,特别是在滚动位置频繁变化的状态下,因为设置 itemExtent 可以让滚动系统提前知道列表的长度。...(当选择将列表项包裹在 RepaintBoundary 时,在滚动过程中可以避免重绘,如果此列表项需要自己维护 KeepAlive 状态,那么此参数需为 false) addSemanticIndexes...(当选择将列表项包裹在 RepaintBoundary 时,在滚动过程中可以避免重绘,如果此列表项需要自己维护 KeepAlive 状态,那么此参数需为 false) addSemanticIndexes

    8.8K51

    Flutter 构建完整应用手册-联网 顶

    从互联网上获取数据 从大多数应用程序获取互联网上的数据是必要的。 幸运的是,Dart和Flutter为这类工作提供了工具!...路线 使用http包发出网络请求 将响应转换为自定义Dart对象 用Flutter获取并显示数据 1.使用http包发出网络请求 http包提供了从互联网获取数据的最简单方法。...3.用Flutter获取并显示数据 为了获取数据并将其显示在屏幕上,我们可以使用FutureBuilder小部件! Flutter附带FutureBuilder部件,可以轻松处理异步数据源。...StreamBuilder部件将连接到Stream,并在每次接收到事件时使用给定的builder函数请求Flutter重建!...; 这个怎么用 WebSocketChannel提供了一个StreamSink来将消息推送到服务器。 StreamSink类提供了将同步或异步事件添加到数据源的一般方法。

    2.6K20
    领券