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

Flutter无限滚动总是重置视图

是指在使用Flutter开发应用时,当实现无限滚动列表或视图时,滚动到一定位置后,视图会重置回初始状态,导致用户无法无限滚动查看内容。

为了解决这个问题,可以采用以下方法:

  1. 使用ListView.builder或ListView.custom构建列表视图,而不是ListView。这两个构造函数可以根据需要动态创建列表项,避免重置视图的问题。
  2. 在ListView.builder或ListView.custom中设置itemExtent属性,指定列表项的固定高度。这样可以确保列表项的高度不会随着滚动而变化,避免重置视图。
  3. 使用ScrollController来控制滚动位置。可以通过监听滚动事件,当滚动到列表底部时,加载更多数据并更新列表视图。这样可以实现无限滚动效果。
  4. 使用Flutter的第三方库,如flutter_infinite_listview,它提供了一个无限滚动列表的封装组件,可以方便地实现无限滚动功能。

总结起来,解决Flutter无限滚动总是重置视图的问题,可以使用ListView.builder或ListView.custom构建列表视图,设置itemExtent属性,使用ScrollController控制滚动位置,或者使用第三方库来简化实现过程。

腾讯云相关产品和产品介绍链接地址:

  • 腾讯云Flutter开发平台:https://cloud.tencent.com/product/flutter
  • 腾讯云移动应用开发服务:https://cloud.tencent.com/product/mad
  • 腾讯云移动推送服务:https://cloud.tencent.com/product/tpns
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Flutter》-- 6.高级组件

参阅书籍: 《Flutter跨平台开发入门与实践》-- 向治洪(著) 6. 高级组件 6.1 可滚动组件 对于列表和长布局的显示溢出问题,可以使用Flutter提供的可滚动组件来处理。...6.1.1 Scrollable组件 在Flutter中,一个可滚动的组件直接或间接包含一个Scrollable组件,它是可滚动组件的基础组件。...如果一个可滚动组件支持Sliver,那么该可滚动组件可以将子组件分成多个Sliver,只有当Sliver出现在视图窗口时才会去构建它,从而提高渲染的性能。...,//是否是与父级关联的主滚动视图 this.physics,//设置滚动效果 this.controller,//控制滚动位置,当primary为true时,controller必须为null...:视图窗口内部长度,大小等于屏幕显示的列表长度; extentAfter:列表中未滑入视图窗口部分的长度; atEdge:是否滚动到了可滚动组件的边界。

10.5K20

UITableView在Flutter中是什么?

ListView 在Flutter中,ListView可以沿一个方向(垂直或者水平方向)来排列其所有子Widget,因此常被用于需要展示一组连续视图元素的场景,比如通讯录、优惠券、商家列表等。...当列表滚动到相应位置时,ListView会调用该方法创建对应的子Widget。 itemCount,表示列表项的数量,如果为空,则表示ListView为无限列表。...这时,各自视图滚动和布局模型就是相互独立、分离的,就很难保证整个页面统一一致的滑动效果。 那么,Flutter是如何解决多ListView嵌套时,页面滑动效果不一致的问题的呢?...在Flutter中,有一个专门的控件CustomScrollView,用来处理多个需要自定义滚动效果的Widget。...总结 在处理展示一组连续、可滚动视图元素的场景中,Flutter提供了比原生Android、iOS系统更为强大的列表组件ListView与CustomScrollView。

5.5K10

开始使用-编写你的第一个Flutter应用程序 顶

第1步:创建起始Flutter应用程序 第2步:使用外部包装 第3步:添加一个有状态的小部件 第4步:创建一个无限滚动ListView 第5步:添加交互性 第6步:导航到新的屏幕 第7步:使用主题更改UI...这个类将保存随着用户滚动无限增长的生成的单词对,以及最喜欢的单词对,因为用户通过切换心脏图标来将它们从列表中添加或删除。 你会一点一点地建立这个类。...lib/main.dart 第4步:创建一个无限滚动ListView 在这一步中,您将展开RandomWordsState以生成并显示单词配对列表。...当用户滚动时,ListView小部件中显示的列表将无限增长。 ListView的builder工厂构造函数允许您根据需要懒惰地构建列表视图。...用ListView和ListTiles创建一个延迟加载的无限滚动列表。 创建了一条路由并添加了在主路由和新路由之间移动的逻辑。 了解如何使用主题更改应用UI的外观。

9.5K20

Flutter可滑动组件

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

7.1K30

Flutter 首页必用组件NestedScrollView

老孟导读:昨天Flutter 1.17版本重磅发布,新的版本主要是优化性能、修复bug,有人觉得此版本毫无亮点,但也从另一方面体现了Flutter目前针对移动端已经较为完善,想了解具体内容,文末有链接,...NestedScrollView 可以在其内部嵌套其他滚动视图的组件,其滚动位置是固有链接的。...reverse参数表示反转滚动方向,并不是由垂直转为水平,而是垂直方向滚动时,默认向下滚动,reverse设置false,滚动方向改为向上,同理水平滚动改为水平向左。...controller为滚动控制器,可以监听滚到的位置,设置滚动的位置等,用法如下: _scrollController = ScrollController(); //监听滚动位置 _scrollController.addListener...有: AlwaysScrollableScrollPhysics:总是可以滑动 NeverScrollableScrollPhysics:禁止滚动 BouncingScrollPhysics :内容超过一屏

4.1K10

10分钟了解Flutter跨平台运行原理!

Flutter目标是使开发人员能够交付在不同平台上都感觉自然流畅的高性能应用程序。兼容滚动行为、排版、图标等方面的差异。那么Flutter是如何编译成原生app的呢?...这样不仅可以保证视图渲染在Android和iOS上的高度一致性(即高保真),在代码执行效率和渲染性能上也可以媲美原生App的体验(即高性能)。那Flutter是怎么运行的呢?...可以看到,Flutter关注如何尽可能快地在两个硬件时钟的VSync信号之间计算并合成视图数据,然后通过Skia交给GPU渲染:UI线程使用Dart来构建视图结构数据,这些数据会在GPU线程进行图层合成...Flutter会把所有的渲染对象绘制到不同的图层上。与布局过程一样,绘制过程也是深度优先遍历,而且总是先绘制自身,再绘制子节点。...ScrollView滚动的时候需要刷新视图内容,从而触发内容重绘。而当滚动内容重绘时,一般情况下其他内容是不需要重绘的,这时候重绘边界就派上用场了。

5.9K40

Flutter

Flutter 会把所有的渲染对象绘制到不同的图层上。与布局过程一样,绘制过程也是深度优先遍历,而且总是先绘制自身,再绘制子节点。...didChangeDependencies 则用来专门处理 State 对象依赖关系变化,会在 initState() 调用结束后,被 Flutter 调用。 build,作用是构建视图。...当状态数据发生变化时,我们总是通过调用这个方法告诉 Flutter:“我这儿的数据变啦,请使用更新后的数据重建 UI!”...当 State 被永久地从视图树中移除时,Flutter 会调用 dispose 函数。而一旦到这个阶段,组件就要被销毁了,所以我们可以在这里进行最终的资源释放、移除监听、清理环境,等等。...以一个有着封面头图的列表为例,我们希望封面头图和列表这两层视图滚动联动起来,当用户滚动列表时,头图会根据用户的滚动手势,进行缩小和展开。

1.9K40

Flutter 2.8 的新特性【flutter专题17】

出于严谨的考虑,在之前的版本中 Flutter 创建平台视图时会阻塞平台线程,这次通过详细的推理和测试 确定了可以删除一些序列化,这个改进消除了在低端设备上启动 Google Pay 期间超过 100...在之前版本的 Flutter 中,platform view 会立即创建一个新的画布,每个额外的平台视图都会添加另一个画布,可是创建额外的画布是很昂贵的,因为每个画布都是整个窗口的大小。...所以该版本会复用早期平台视图创建的画布,这意味着开发者可以在 HtmlElementView 的 Web 应用中拥有多个实例而不会降低性能,同时还可以减少使用平台视图时的滚动卡顿。...以前 DartPad 总是运行最新的稳定版本,在此版本中可以使用状态栏中的新频道菜单,来选择最新的 Beta 频道版本以及之前的稳定版本(称为“旧频道”)。...生态系统 Flutter 不仅仅是框架、引擎和工具——pub.dev 上有超过 20,000 个与 Flutter 兼容的包和插件,而且每天都在增加。

2.4K10

Flutter技术与实战(2)

Flutter 使用 Native 引擎渲染视图,并提供了丰富的组件和接口,这无疑为开发者和用户都提供了良好的体验。...Flutter如何完成组件渲染 Flutter 关注如何尽可能快地在两个硬件时钟的 VSync 信号之间计算并合成视图数据,然后通过 Skia 交给 GPU 渲染:UI 线程使用 Dart 来构建视图结构数据...Flutter 会把所有的渲染对象绘制到不同的图层上。与布局过程一样,绘制过程也是深度优先遍历,而且总是先绘制自身,再绘制子节点。...ScrollView 滚动的时候需要刷新视图内容,从而触发内容重绘。而当滚动内容重绘时,一般情况下其他内容是不需要重绘的,这时候重绘边界就派上用场了。...在 Flutter 中,Widget 是整个视图描述的基础,在 Flutter 的世界里,包括应用、视图视图控制器、布局等在内的概念,都建立在 Widget 之上,Flutter 的核心设计思想便是一切皆

1.4K10

Flutter布局指南之深入理解BoxConstraints

,但事实上,你会经历多次错误和失败,Flutter的Widget并不会总是像你想象的那样进行布局。...double.infinity这个值意味着Widget可以有无限的尺寸。 你可能会遇到有界和无界约束这两个术语。有界意味着有限的约束,即一些特定的尺寸,而无界约束意味着无限的尺寸,即无穷大。...❞ 案例:在父Widget设置的约束条件的同时添加额外的约束条件 ❝用ConstrainedBox包住子Widget ❞ 案例:在滚动的父Widget内限制一个子Widget的大小,在其滚动方向上有无限制的约束...这是因为Flutter不能渲染无限的尺寸。父方或子方都必须设置一个边界,以便框架知道它需要渲染的尺寸。 像ListView这样的滚动Widget在其滚动方向上有Unbounded约束。...Flutter不能渲染无限大的尺寸。

2K20

Flutter技术与实战(4)

当状态数据发生变化时,我们总是通过调用这个方法告诉 Flutter:“我这儿的数据变啦,请使用更新后的数据重建 UI!”...当列表滚动到相应位置时,ListView 会调用该方法创建对应的子 Widget。 itemCount,表示列表项的数量,如果为空,则表示 ListView 为无限列表。...这时,各自视图滚动和布局模型就是相互独立、分离的,就很难保证整个页面统一一致的滑动效果。 Flutter 是如何解决多 ListView 嵌套时,页面滑动效果不一致的问题的呢?...在 Flutter 中有一个专门的控件 CustomScrollView,用来处理多个需要自定义滚动效果的 Widget。...ListView 的组件控制器则是 ScrollControler,我们可以通过它来获取视图滚动信息,更新视图滚动位置。

10.7K20

Flutter 渲染性能问题分析

,Web (Chromium) 的惯性滚动动画性能理论上要远远优于 Flutter。...) > Flutter (Android) 我们在不同设备上对上述业务页面在惯性滚动过程中进行 trace 的抓取,结合 Flutter 的代码对 trace 文件进行分析,了解 Flutter 渲染流水线在惯性滚动过程中各个环节的调度...Web (Chromium),Flutter 在上述两方面都存在比较明显的劣势: img Flutter 需要依赖于 Relayout 来驱动惯性滚动动画,滚动容器内的元素在滚动过程中每一帧都需要 Relayout...Flutter无限长列表一般都采用 Lazy Build 的方式生成列表单元,当列表单元接近可见区域的时候,框架才调用应用提供的 Builder 生成列表单元的 Widget 树并进行布局,新挂载的列表单元的...View 树的数据然后局部重排即可,耗时会大大少于 Flutter 整个列表单元的完整 Build & Layout,这是 Native (Android) 的无限长列表滚动更流畅的主要原因。

2.6K20

Flutter区别于其他技术的关键是什么?

Flutter采用自带的Native渲染引擎渲染视图,它是自己完成了组件渲染的闭环;而RN、Weex之类的框架,只是通过JavaScript虚拟机扩展调用系统组件,最后是由Android或者iOS系统来完成组件的渲染...可以看到,Flutter关注如何尽可能快地在两个硬件时钟的Vsych之间计算并合成视图数据,然后通过Skia交给GPU渲染:UI线程使用Dart来构建视图结构数据,这些数据会在GPU线程进行图层合成,随后交给...而Engine层的作用,则是将他们组合起来,从他们生成的数据中实现视图渲染。 Framework层则是一个用Dart实现的UI SDK,包含了动画、图形绘制和手势识别等功能。...Flutter会把所有的渲染对象,绘制到不同的图层上。与布局过程一样,绘制过程也是深度优先遍历,而且总是先绘制自身,再绘制子节点。...ScrollView滚动的时候需要刷新视图内容,从而触发内容重绘。而当滚动内容重绘时,一般情况下其他内容是不需要重绘的,这时候重绘边界就派上用场了。

2.7K30

Flutter 首页必用组件NestedScrollView的示例详解

昨天Flutter 1.17版本重磅发布,新的版本主要是优化性能、修复bug,有人觉得此版本毫无亮点,但也从另一方面体现了Flutter目前针对移动端已经较为完善,想了解具体内容,文末有链接,如果你想升级到最新版本...可以在其内部嵌套其他滚动视图滚动视图,其滚动位置是固有链接的。...reverse参数表示反转滚动方向,并不是由垂直转为水平,而是垂直方向滚动时,默认向下滚动,reverse设置false,滚动方向改为向上,同理水平滚动改为水平向左。...controller为滚动控制器,可以监听滚到的位置,设置滚动的位置等,用法如下: _scrollController = ScrollController(); //监听滚动位置 _scrollController.addListener...交流 Flutter博客地址(近200个控件用法):http://laomengit.com 总结 到此这篇关于Flutter 首页必用组件NestedScrollView的文章就介绍到这了,更多相关Flutter

3.6K40

ListView&GirdView

ListView,所以要好好看下这篇文章哦 还是先来看下listView的构造方法: ListView({ Key key, Axis scrollDirection: Axis.vertical,//滚动方向...bool reverse: false,//十分反向显示数据 ScrollController controller, bool primary, ScrollPhysics physics,//物理滚动...false, EdgeInsetsGeometry padding, this.itemExtent,//item有效范围 bool addAutomaticKeepAlives: true,//自动保存视图缓存...如果有未知数量或者无限个Item的情况,再使用上述的方法将不再适用。 那么,我们可以尝试下ListView.builder()和ListView.custom()。...小结 ---- ListView就是我们常用的列表视图 GridView就是我们常用的宫格视图 ListView和GridView都可以使用new 或者builder()和custom()方法来创建对象

1.7K20

——Flutter与其他方案的区别

Flutter使用Native引擎渲染视图,并提供了丰富的组件和接口,这无疑为开发者和用户都提供了良好的体验。...Flutter关注如何尽可能快地在两个硬件时钟的VSync信号之间计算并合成视图数据,然后通过Skia交给GPU渲染:UI线程使用Dart来构建视图结构数据,这些数据会在GPU线程进行图层合成,随后交给...因为,Flutter只关心如何向GPU提供视图数据,而Skia就是它向GPU提供视图数据的好帮手。 Skia是C++开发、性能彪悍2D图像绘制引擎,其前身是一个向量绘图软件。...Flutter会把所有的渲染对象绘制到不同的图层上。与布局过程一样,绘制过程也是深度优先遍历,而且总是先绘制自身,再绘制子节点。...ScrollView滚动的时候需要刷新视图内容,从而触发内容重绘。而当滚动内容重绘时,一般情况下其他内容是不需要重绘的,这时候重绘边界就派上用场了。

40920

Flutter完整开发实战详解(二十、 Android PlatformView 和键盘问题)

作为系列文章的第二十篇,本篇将结合官方的技术文档科普 Android 上 PlatformView 的实现逻辑,并且解释为什么在 Android 上 PlatformView 的键盘总是有问题。...在 iOS 平台上就不使用类似 VirtualDisplay 的方法,而是通过将 Flutter UI 分为两个透明纹理来完成组合:一个在 iOS 平台视图之下,一个在其上面。...所以这样的好处就是:需要在“iOS平台”视图下方呈现的Flutter UI,最终会被绘制到其下方的纹理上;而需要在“平台”上方呈现的Flutter UI,最终会被绘制在其上方的纹理。...在代理线程中,返回 Flutter View 以创建输入。。 WebView 失去焦点时,将输入连接重置Flutter 线程。这样可以防止文本输入“卡”在 WebView 内。...相关的 issue 专题高居不下,并且如 webview_flutter 插件的文档所述: 该插件依赖 Flutter 的新机制来嵌入 Android 和 iOS 视图

13.3K20

无限滚动加载最佳实践

无限滚动(Infinite scrolling),有时候被称为无尽滚动(endless scrolling),这种技术允许用户在大量内容上滚动,眼中看不到结束的地方。...优秀无限滚动的五项原则 将无限滚动做好,并不是不可能完成的任务。为了完成它,记住并遵守以下方针。 1....实际上,这也是无限滚动设计的主要挑战之一:用户到达列表底部的时候,内容在不断地加载进来,用户会有一两秒时间看到页脚,直到下一组结果加载成功并将页脚挤出视图之外。这阻止用户接触到页脚。...但是列表的位置不再存在了,这意味着使用浏览器的返回按钮一般都导致滚动位置重置到页面顶部。无怪乎用户很快就觉得沮丧,都没有一个合适的“回到列表”的功能。 ?...结论 无限滚动实现得好的话,可以达到令人难以置信的光滑无缝体验。很好的是,关于好的无限滚动,你已经获得一些线索了,这会帮你建立完美的用户体验。

4.2K20
领券