【Flutter·学习实践·UI篇】基础且重要的UI知识

这篇具有很好参考价值的文章主要介绍了【Flutter·学习实践·UI篇】基础且重要的UI知识。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

参考学习官网:《Flutter实战·第二版》 

学习前先记住:Flutter 中万物皆为Widget,心中默念3次以上铭记于心。

这一点和开发语言Dart的变量一切皆是对象的概念,相互对应。

 Widget 

在前面的介绍中,我们知道在Flutter中几乎所有的对象都是一个 widget 。与原生开发中“控件”不同的是,Flutter 中的 widget 的概念更广泛,它不仅可以表示UI元素,也可以表示一些功能性的组件如:用于手势检测的 GestureDetector 、用于APP主题数据传递的 Theme 等等,而原生开发中的控件通常只是指UI元素。在后面的内容中,我们在描述UI元素时可能会用到“控件”、“组件”这样的概念,读者心里需要知道他们就是 widget ,只是在不同场景的不同表述而已。

Flutter 主要核心就是用于构建用户界面,说白了它做的界面可以跨平台,就只做界面,大部分开发认为 widget 就是一个控件,不必纠结于概念。

Widget 接口了解

  • @immutable 代表 Widget 是不可变的,Flutter 中如果属性发生变化则会重新构建Widget树
  • Widget 中定义的属性必须是 final
  • Widget类继承自DiagnosticableTree,DiagnosticableTree即“诊断树”,提供调试信息。
  • Key:主要的作用是决定是否在下一次build时复用旧的 widget (决定的条件在canUpdate()方法中)
  • createElement():一个 widget 可以对应多个Element(在我们开发过程中基本不会调用到
  • debugFillProperties(...) 复写父类的方法,主要是设置诊断树的一些特性。
  • canUpdate(...)是一个静态方法,是否用新的 widget 对象去更新旧UI树上所对应的Element对象的配置。(条件是:newWidget与oldWidget的runtimeType和key同时相等时就会用new widget去更新Element对象的配置,否则就会创建新的Element。)

Flutter中的四棵树

先看示意图:

flutter ui组件,Flutter,Dart

 最后一棵树是渲染树在上屏前会生成的 Layer 树,暂时不做讨论

  • WidgetTree:存放渲染内容、它只是一个配置数据结构,创建是非常轻量的,在页面刷新的过程中随时会重建
  • Element 是分离 WidgetTree 和真正的渲染对象的中间层, WidgetTree 用来描述对应的Element 属性,同时持有Widget和RenderObject,存放上下文信息,通过它来遍历视图树,支撑UI结构。
  • RenderObject (渲染树)用于应用界面的布局和绘制,负责真正的渲染,保存了元素的大小,布局等信息,实例化一个 RenderObject 是非常耗能的

StatelessWidget

它继承自widget类,重写了createElement()方法

@override
StatelessElement createElement() => StatelessElement(this);

 StatelessElement 间接继承自Element类,与StatelessWidget相对应(作为其配置数据)。

StatelessElement用于不需要维护状态的场景,它通常在build方法中通过嵌套其他 widget 来构建UI,在构建过程中会递归的构建其嵌套的 widget 。

StatefulWidget

和StatelessWidget一样,StatefulWidget也是继承自widget类,并重写了createElement()方法,不同的是返回的Element 对象并不相同;另外StatefulWidget类中添加了一个新的接口createState()。

StatefulWidget的类定义:

abstract class StatefulWidget extends Widget {
  const StatefulWidget({ Key key }) : super(key: key);
    
  @override
  StatefulElement createElement() => StatefulElement(this);
    
  @protected
  State createState();
}

StatefulElement 间接继承自Element类,与StatefulWidget相对应(作为其配置数据)。StatefulElement中可能会多次调用createState()来创建状态(State)对象。

createState() 用于创建和 StatefulWidget 相关的状态,它在StatefulWidget 的生命周期中可能会被多次调用。

StatelessWidget 和 StatefulWidget 都是用于组合其他组件的,它们本身没有对应的 RenderObject。

StatelessWidget:无状态使用;

StatefulWidget:有状态,且可变时使用;

StatelessWidget和StatefulWidget一定要记住写UI经常用到。 

State

一个 StatefulWidget 类会对应一个 State 类,State表示与其对应的 StatefulWidget 要维护的状态,State 中的保存的状态信息允许:

  1. 在 widget 构建时可以被同步读取。
  2. 在 widget 生命周期中可以被改变,当State被改变时,可以手动调用其setState()方法通知Flutter 框架状态发生改变,Flutter 框架在收到消息后,会重新调用其build方法重新构建 widget 树,从而达到更新UI的目的。

State 中有两个常用属性:

  1. widget,它表示与该 State 实例关联的 widget 实例,由Flutter 框架动态设置。
  2. context,StatefulWidget对应的 BuildContext,作用同StatelessWidget 的BuildContext。

State生命周期 :看官方实例

initState:当 widget 第一次插入到 widget 树时会被调用,对于每一个State对象,Flutter 框架只会调用一次该回调。

didChangeDependencies :当State对象的依赖发生变化时会被调用。

build:主要是用于构建 widget 子树。

didUpdateWidget:在 widget 重新构建时,Flutter 框架会调用widget.canUpdate来检测 widget 树中同一位置的新旧节点,然后决定是否需要更新,如果widget.canUpdate返回true则会调用此回调。

reassemble:热重载(hot reload)时会被调用,此回调在Release模式下永远不会被调用

deactivate:State 对象从树中被移除时,会调用此回调。

dispose:当 State 对象从树中被永久移除时调用;通常在此回调中释放资源

flutter ui组件,Flutter,Dart

 在 widget 树中获取State对象

由于 StatefulWidget 的的具体逻辑都在其 State 中,所以很多时候,我们需要获取 StatefulWidget 对应的State 对象来调用一些方法。

获取state对象的几种方法

  1. context对象的findAncestorStateOfType()方法;
    1. ScaffoldState _state = context.findAncestorStateOfType<ScaffoldState>()!;
    2. 直接通过of静态方法来获取State对象:(ScaffoldState _state=Scaffold.of(context);)
  2. 通过GlobalKey
    1. //定义一个globalKey, 由于GlobalKey要保持全局唯一性,我们使用静态变量存储
      static GlobalKey<ScaffoldState> _globalKey= GlobalKey();
      ...
      Scaffold(
          key: _globalKey , //设置key
          ...  
      )
      2. 通过GlobalKey来获取State对象
      _globalKey.currentState.openDrawer()

注意:使用 GlobalKey 开销较大,如果有其他可选方案,应尽量避免使用它。另外,同一个 GlobalKey 在整个 widget 树中必须是唯一的,不能重复。

 文章来源地址https://www.toymoban.com/news/detail-618197.html

到了这里,关于【Flutter·学习实践·UI篇】基础且重要的UI知识的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Flutter系列文章-Flutter UI进阶

    在本篇文章中,我们将深入学习 Flutter UI 的进阶技巧,涵盖了布局原理、动画实现、自定义绘图和效果、以及 Material 和 Cupertino 组件库的使用。通过实例演示,你将更加了解如何创建复杂、令人印象深刻的用户界面。 Row 和 Column 是常用的布局组件,但灵活地使用它们可以带来

    2024年02月13日
    浏览(22)
  • Flutter的优质UI组件库

    1. Get Widget 国外开发的,应对一些flutter中缺少的组件库 文档地址:https://docs.getwidget.dev 2.Bruno Bruno 是贝壳公司开发的,基于一整套设计体系的 Flutter 组件库。 文档地址:https://bruno.ke.com/page/guide/bruno 3.macos_ui 专注于macOS,实现当前macOS设计的Flutter小部件和主题。 文档地址:h

    2024年02月11日
    浏览(37)
  • Flutter TextField UI 实例 —— 新手礼包

    大家好,我是17。 新手礼包一共 3 篇文章,每篇都是描述尽量详细,实例讲解,包会! Flutter Row 实例 —— 新手礼包 Flutter TextField UI 实例 —— 新手礼包 Flutter TextField 交互实例 —— 新手礼包 本篇介绍了 TextField UI 的常见写法,从TextField的尺寸,border,icon,文本到光标,无所

    2023年04月08日
    浏览(21)
  • Flutter 单线程模型保证UI运行流畅

    Flutter 框架出色的渲染和交互能力。支撑起这些复杂的能力背后,实际上是基于单线程模型的 Dart。那么,与原生 Android 和 iOS 的多线程机制相比,单线程的 Dart 如何从语言设计层面和代码运行机制上保证 Flutter UI 的流畅性呢? 因此今天,我会通过几个小例子,循序渐进地向你

    2024年02月16日
    浏览(26)
  • Flutter使用stack来实现悬浮UI

    在Flutter中,你可以使用Stack和Positioned来创建悬浮 UI。Stack允许你将多个小部件叠放在一起,而Positioned则用于定位小部件在Stack中的位置。 以下是一个简单的示例,演示如何创建一个悬浮按钮: 在这个例子中,MyFloatingUI是一个StatefulWidget,它包含一个Stack,其中包括了一个主要

    2024年01月25日
    浏览(24)
  • Flutter悬浮UI的设计Overlay组件

    有时候我们在开发APP的时候会遇到下面这些需求: 在现有页面上添加浮动的悬浮按钮、气泡或菜单。 实现全局的通知或提示弹窗。 创建自定义的导航栏、底部导航或标签栏。 构建模态对话框或底部弹出菜单。 在屏幕上展示悬浮窗,比如 Flutter 版本的 Toast,任意位置的 Pop

    2024年02月09日
    浏览(25)
  • Flutter实现Service + UI 全面跨平台

    作者:Karl_wei Flutter作为跨平台的UI框架,其可行性已经被市场所认可。UI跨端后,我们自然会希望一些运行在 终端的小服务也能跨端 ,特别是当这个小服务还涉及到一些 UI 的展示。 我们希望Flutter能承担这个角色,让其跨端能力更进一步。 我们希望在整机设备上,运行一个

    2024年02月12日
    浏览(26)
  • metaRTC集成flutter ui demo编译指南

    Flutter是由Google开发的开源UI工具包,用于构建跨平台应用程序,支持linux/windows/mac/android/ios等操作系统。 metaRTC新增flutter demo,支持linux/windows/mac/android/ios操作系统,此demo在ubuntu桌面环境下测试成功。 Release metartc7.0.072 with 3rdparty and runtime · metartc/metaRTC · GitHub A cross-platform we

    2024年02月06日
    浏览(33)
  • 笔记:flutter中一些流行的 UI 相关库

    CSDN:https://jclee95.blog.csdn.net 本文收录了很多在 flutter pub 上显示流行度较高的第三方UI库和UI框架,对它们的效果进行了截图,目的是方便开发时进行查找; 这些模块多数来自于 flutter pub 官方主页 Flutter Favorites 、 Most popular packages 、 Top Flutter packages 也有一些仅仅只 popularity 值

    2024年02月15日
    浏览(35)
  • 探索 Flutter Effects: 打造生动有趣的 UI 动画

    项目地址:https://gitcode.com/HitenDev/flutter_effects Flutter 是 Google 推出的一款跨平台的移动应用开发框架,以其高效、易于学习和丰富的视觉效果赢得了开发者们的喜爱。今天,我们要向您推荐一个特别的 Flutter 项目:Flutter Effects。这是一个开源库,集合了一系列创意十足的 UI 动画

    2024年04月29日
    浏览(22)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包