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

Flutter,如何让SingleChildScrollView中子控件的高度匹配父控件?

模型出错了,请稍后重试~

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

不一样角度带你了解 Flutter 中的滑动列表实现

「本篇不是教你如何使用 API ,而是一些日常开发中不常接触,但是很重要的内容」。...Flutter 滑动列表 在 Flutter 里我们常见的滑动列表场景,简单地说其实是由三部分组成: Viewport :它是一个 MultiChildRenderObjectWidget 的控件 ,「... 使用的是 SliverFillViewport; 当然这里有一个特殊的是 SingleChildScrollView , 因为它是单个 child 的可滑动控件,它并没有使用 RenderSliver...,那他们之间是滑动关系是如何处理的?... SliverOverlapAbsorber 用于吸收 SliverPersistentHeader 的高度; 使用 SliverOverlapInjector 将这个高度配置到 body 列表中,让列表知道顶部存在一个固定高度的区域

1.1K30
  • Flutter SingleChildScrollView 滚动控件

    Flutter中的SingleChildScrollView类似于Android中的ScrollView,它只能接收一个子组件。...树中默认的`PrimaryScrollController` this.physics, //决定可滚动组件如何响应用户操作,滑动到边界时,出现弹性(ios)还是微光(android) this.controller...需要注意的是,通常SingleChildScrollView只应在期望的内容不会超过屏幕太多时使用,这是因为SingleChildScrollView不支持基于Sliver的延迟实例化模型,所以如果预计视口可能包含超出屏幕尺寸太多的内容时...2、基本概念:基于Sliver的延迟构建 通常可滚动组件的子组件可能会非常多、占用的总高度也会非常大;如果要一次性将子组件全部构建出将会非常昂贵!...为此,Flutter中提出一个Sliver(中文为”薄片“的意思)概念,如果一个可滚动组件支持Sliver模型,那么该滚动可以将子组件分成好多个”薄片“(Sliver),只有当Sliver出现在视口中时才会去构建它

    5.2K00

    经典布局:如何定义子控件在父容器中的排版位置?

    在Flutter中,一个完整的界面通常就是由这些小型、单用途的基本控件元素依据特定的布局规则堆砌而成的。...Flutter提供了31种布局Widget,对布局控件的划分非常详细,一些相同(或相似)的视觉效果可以通过多种布局控件实现,因此布局类型相比原生iOS、Android平台多了不少。...在Flutter中,Container本身可以单独作为控件存在(比如单独设置背景色、宽高),也可以作为其他控件的父级存在:Container可以定义布局过程中子Widget如何摆放,以及如何展示。...需要注意的是,对于主轴而言,Flutter默认是让父容器决定其长度,即尽可能大。 在上例中,Row的宽度为屏幕宽度,Column的高度为屏幕高度。...如果想让容器与子Widget在主轴上完全匹配,我们可以通过设置Row的mainAxisSize参数为MainAxisSize.min,由所有子Widget来决定主轴方向的容器长度,即主轴方向的长度尽可能小

    4.6K30

    「0821更新」Flutter入门系列教程汇总

    本系列持续更新中,欢迎关注我的博客:maomao.ink 环境搭建 环境搭建(mac os为例) 项目运行:Hello world 基础控件 Flutter Text(文本控件) Flutter Button...(按钮控件) Flutter TextField(输入控件) Flutter Image(图片控件) Flutter Icon IconFont(图标控件) Flutter Row、Column 线性布局...Flutter Stack、Positioned 层叠布局 Flutter SingleChildScrollView 滚动控件 Flutter ListView 列表控件New Flutter ListView...下拉刷新,上拉加载更多New Flutter GridView 网格控件New 常见问题 Flutter:从网络获取数据遇到的坑 Flutter问题:Column里面嵌套两个SingleChildScrollView...无法滚动 Flutter问题:import 'package:english_words/english_words.dart'失败New Android/Flutter组件映射表 Android Flutter

    1K20

    Flutter Widgets 之 Expanded和Flexible

    Expanded和Flexible是控制Row、Column、Flex的子控件如何布局的控件,Expanded和Flexible可以扩张填满主轴剩余空间,如何确认主轴和交叉轴可以查看[Flutter Widgets...Container默认是适配子控件大小的,但当设置对齐方式时Container将会填满父控件,在Flutter Widgets 之 Container中已经详细介绍,因此是否填满剩余空间取决于子控件是否需要填满父控件...如果把Flexible中子控件由Container改为OutlineButton,代码如下: Row( children: [ Container(...Colors.blue, height: 50, width: 100, ), ], ) OutlineButton正常情况下是不充满父控件的...这里总结下Expanded和Flexible的区别: - Expanded:强制填满剩余空间 - Flexible:不强制填满剩余空间,是否填满剩余空间取决于子控件是否需要填满父控件。

    1.4K20

    【Flutter实战】定位装饰权重组件及柱状图案例

    不,不会,子控件依然会受到父组件的约束,会扩展到父组件的尺寸,还有一个便捷的方式设置此方式: SizedBox.expand( child: Text('老孟,专注分享Flutter技术及应用'),...,可以控制 Row、Column、Flex 的子控件如何布局的组件。...Flexible 组件可以控制 Row、Column、Flex 的子控件占满父组件,比如,Row 中有3个子组件,两边的宽是100,中间的占满剩余的空间,代码如下: Row( children...大家是否还记得 Container 组件的大小是如何调整的吗?...Container 默认是适配子控件大小的,但当设置对齐方式时 Container 将会填满父组件,因此是否填满剩余空间取决于子组件是否需要填满父组件。

    1.4K10

    Flutter自定义view —— 闯关进度条

    概述 因工作需要,需要自定义实现一个布局,当然用横向Row控件也可以实现这个效果, 但我觉得还是用自定义 view 实现效果比较好,想要什么效果都可以去实现,所以我按照 自己的想法写了一下这个自定义布局...appBar: new AppBar( title: new Text('custom_View'), ), body: SingleChildScrollView...,必须获取文字的宽高,然后再去设置文字的坐标点(Android 需要计算基线,flutter不需要) 绘制是从下往上绘制,也就是说先绘制的在下面,注意绘制时的遮盖问题。...坐标点的计算 1.绘制每个控件都需要准确的坐标,圆的圆心坐标点,进度线的起始点与终点坐标点,自己在纸上画一画, 找到规律,总结成一个公式,然后套用。...2.还要在最外面设置size大小,size 大小也是动态计算的,计算出整个控件的宽度,高度可以定死 ---------- 有啥不明白的随时联系我,稍后我会上传github,如果能帮助到你,麻烦点个赞

    97930

    Flutter 入门指北之滑动部件(超详细)

    现在给前面写的 Text 包裹上一层 SingleChildScrollView 然后再运行,文字全部都展示出来了。...)), 如果每个 item 的高度可以确定,那么推荐通过 itemExtent 来设置 item 的高度/宽度,能够加快 ListView 的渲染速度。...为了方便写法呢,Flutter 对以上的两种方式进行了封装,省略了 delegate GridView.count/GridView.extent 直接看下如何修改 // 这种情况简化了 `GridView...因为 GridView 和 ListView 亮着都是可滑动的部件,直接拼接肯定会有「滑动冲突」,所以 Flutter 就提供了一个粘合剂,CustomScrollView,那么 Flutter 如何实现呢...在结束前,我们再说下如何通过 ScrollController 来控制 Scrollable 的滚动位置。

    2.5K30

    Flutter技术与实战(4)

    因此,在 ListView 中,指定 itemExtent 比让子 Widget 自己决定自身高度会更高效。...经典布局:如何定义子控件在父容器中的排版位置 Flutter 提供了 31 种布局 Widget,对布局控件的划分非常详细,一些相同(或相似)的视觉效果可以通过多种布局控件实现。...在 Flutter 中,Container 本身可以单独作为控件存在(比如单独设置背景色、宽高),也可以作为其他控件的父级存在:Container 可以定义布局过程中子 Widget 如何摆放,以及如何展示...* 需要注意的是,对于主轴而言,Flutter 默认是让父容器决定其长度,即尽可能大,类似 Android 中的 match_parent。...* 如果想让容器与子 Widget 在主轴上完全匹配,我们可以通过设置 Row 的 mainAxisSize 参数为 MainAxisSize.min,由所有子 Widget 来决定主轴方向的容器长度,

    10.9K20

    Flutter原理:三棵重要的树(渲染过程、布局约束、应用视图的构建等)

    我们也可以看到上图中每个控件所形成的树结构中隐含了一些关系,例如在上图中,我们可以说 Text 组件是 Column 组件的子组件,Scaffold 是 AppBar 的父组件,这样的层级关系使得每个控件都清晰的连接到了一起...这里,Flutter 中的布局过程可用下图表示,在上述构建完成渲染树后,父渲染对象会将布局约束信息向下传递,子渲染对象根据自己的渲染情况返回 Size,Size 数据会向上传递,最终父渲染对象完成布局过程...方法生成,该对象内部提供多个属性及方法来帮助框架层中的组件如何布局渲染。...该约束规定了允许每个子节点的最大和最小宽度和高度。如下图,父节点传入 Min Width 为 150,Max Width 为 300 的 BoxConstraints: ?...当子节点接受到该约束,便可以取得上图中绿色范围内的值,即宽度在 150 到 300 之间,高度大于 100,当取得具体的值之后再将取得具体的大小的值上传给父节点,从而达到父子的布局通信。

    1.8K40

    Flutter

    初次运行时的三棵树 初步认识了三棵树之后,那Flutter是如何创建布局的?以及三棵树之间他们是如何协同的呢?...Flutter 通过控件树中的每个控件创建不同类型的渲染对象,组成渲染对象树。而渲染对象树在 Flutter 的展示过程分为四个阶段:布局、绘制、合成和渲染。...在布局过程中,渲染对象树中的每个渲染对象都会接收父对象的布局约束参数,决定自己的大小,然后父对象按照控件逻辑决定各个子对象的位置,完成布局过程。...五、Flutter的基础 StatelessWidget Widget 采用由父到子、自顶向下的方式进行构建,父 Widget 控制着子 Widget 的显示样式,其样式配置由父 Widget 在构建时提供...flexibleSpace 可以让背景图显示在 AppBar 下方,高度和 SliverAppBar 一样; 而在创建 SliverList 时,通过 SliverChildBuilderDelegate

    1.9K40
    领券