Flutter Widget and Bald(上)

简介: Flutter Widget and Bald

Flutter 是什么?


我们先来搬运官网的一段介绍,让大家有一个直观的认识:


Flutter是谷歌的移动UI框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。
Flutter可以与现有的代码一起工作。在全世界,Flutter正在被越来越多的开发者和组织使用,并且Flutter是完全免费、开源的。


简而言之


  1. 跨端(移动、Web、桌⾯、嵌⼊式)


  1. ⾼性能(Dart)


  1. ⾼效开发(热重载)


  1. 富有表现⼒的 UI(Widget)


温馨提示


  • 搭建开发环境


  • Dart简介


  • ......


这些我们都不讲,今天我们聊一下 Flutter Widget 。让我们开始吧~


Widget 简介


概念


Widget 描述了在当前的配置和状态下,视图所应该 呈现的样⼦。当 Widget 的状态改变时,它会重新构 建其描述(展示的 UI),框架则会对⽐前后变化的 不同,以确定底层渲染树从⼀个状态转换到下⼀个状 态所需的最⼩更改。


Widget目录



描述元素的配置


示例-1



示例-2



Widget 结构



Widget 组合的结构是树,所以叫Widget 树。树中包含


  • 根Widget


  • WidgetsApp【自定义风格】


  • MaterialApp【基于 WidgetsApp的Material Design 风格(常用)


  • CupertinoApp【基于 WidgetsApp 实现的 iOS 风格】


  • 父Widget


  • 子Widget


// main.dart
import 'package:flutter/material.dart'; //风格需要先导入哦~
import 'my_home_page_widget.dart';
void main() => runApp(MyApp());  //Flutter会默认把 根Widget 充满屏幕
class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData.light(),
      home: MyHomePage(title: 'Vava熊の日记'),
    );
  }
}


Widget 与 Element


  • Widget树实际上是一个配置树,而真正的UI渲染树是由Element构成。


  • 一个Widget对象可以对应多个Element对象。根据同一份配置(Widget),可以创建多个实例(Element)。


graph LR
Widget配置--> Element1
Widget配置--> Element2
Widget配置--> Element3
Widget配置--> ...


Widget 状态分类


因为渲染是很耗性能的,为了提高 Flutter 的帧率,就要尽量减少不必要的 UI 渲染,所以 Flutter 根据 UI 是否有变化,将 Widget 分为StatelessWidget && StatefulWidget


StatelessWidgetStatefulWidget都是直接继承自Widget类,它们引入了两种Widget模型,接下来我们将重点介绍一下这两个类。


StatelessWidget:immutable(状态不可变)


StatelessWidget是不可变状态的 Widget 抽象类, 只能在加载/构建 Widget 时才绘制一次,无法基于任何事件或用户操作重绘。所以 StatelessWidget生命周期就只有一个,即 build函数。


StatelessWidget の Demo


// main.dart
import 'package:flutter/material.dart';
import 'stateless.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData.light(),
      home: MyStatelessApp("123 木头人,不许动    ——from Vava熊")
    );
  }
}


//stateless.dart
import 'package:flutter/material.dart';
class MyStatelessApp extends StatelessWidget {
  final String content;
  MyStatelessApp(this.content);
  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar:AppBar(
          title: Text('StatelessWidget'),
        ),
        body:Center(
          child: Text(content),
        )
    );
  }
}


相关文章
|
4天前
|
前端开发 开发者 UED
Flutter的自定义Painter:深入探索自定义绘制Widget的技术实现
【4月更文挑战第26天】Flutter的自定义Painter允许开发者根据需求绘制独特UI,通过继承`CustomPaint`类和重写`paint`方法实现。在`paint`中使用`Canvas`绘制图形、路径等。创建自定义Painter类后,将其作为`CustomPaint` Widget的`painter`属性使用。此技术可实现自定义形状、渐变、动画等复杂效果,提升应用视觉体验。随着Flutter的进化,自定义Painter将提供更丰富的功能。
|
4天前
|
编解码 算法 开发者
Flutter的布局系统:深入探索布局Widget与布局原则
【4月更文挑战第26天】Flutter布局系统详解,涵盖布局Widget(Row/Column、Stack、GridView/ListView、CustomSingleChildLayout)和布局原则(弹性布局、约束优先、流式布局、简洁明了)。文章旨在帮助开发者理解并运用Flutter的布局系统,创建适应性强、用户体验佳的界面。通过选择合适的布局Widget和遵循原则,可实现复杂且高效的UI设计。
|
4天前
|
开发框架 搜索推荐 Android开发
Flutter的Widget基础:概念、分类与深入探索
【4月更文挑战第26天】Flutter Widget详解:基础、分类与工作原理。Widget是Flutter UI的核心,描述界面外观而非直接渲染。分为基础、布局、可滚动及状态管理四大类。基于响应式编程,状态变化时自动更新UI。了解其概念、分类和原理,能助开发者高效构建精美应用。随着Flutter生态发展,Widget系统潜力无限。
|
8月前
|
Dart 前端开发 开发工具
谷歌移动UI框架Flutter教程之Widget
谷歌移动UI框架Flutter教程之Widget
|
9月前
Flutter源码分析笔记:Widget类源码分析
本文记录阅读与分析Flutter源码 - Widget类源码分析。
62 0
Flutter源码分析笔记:Widget类源码分析
|
10月前
|
API Android开发 容器
Flutter控件之基类Widget封装
基类的Widget主要确定以下几个方面,第一就是,自定义一个抽象类还是非抽象类,第二、继承方式,采取有状态还是无状态,第三、关于组件的点击方式,如何进行实现。
105 0
Flutter万物皆为Widget
Flutter 中的 Widget 是描述界面元素的基本单元,可以包含视觉和交互元素。Widget 可以嵌套、组合和扩展,从而构建出复杂的 UI 界面。在 Flutter 中,Widget 可以分为两种类型:StatelessWidget 和 StatefulWidget。
Flutter万物皆为Widget
|
JavaScript 前端开发 开发工具
Flutter | 基础 Widget
Flutter | 基础 Widget
【布局 widget】 Flutter GridView
GridView 独有的参数其实只有一个 gridDelegate,gridDelegate 的作用是为 GridView 布局,制定每行几个 child,空白多少等。
111 0
【布局 widget】 Flutter GridView
|
缓存 前端开发 Java
手写一个Flutter State Widget,来让你彻底理解State的来龙去脉
手写一个Flutter State Widget,来让你彻底理解State的来龙去脉
177 0
手写一个Flutter State Widget,来让你彻底理解State的来龙去脉