Android 、iOS 的 UI 布局的写法

在讲如何写 Flutter UI 之前,首先我们回顾一下 Android 和 iOS 的是如何布局的:

  • Androoid:XML
    Android 中,通过 XML 来写布局。
  • Android:代码
    代码以 命令式 的方法来写布局
  • iOS:Storyboard
    使用 Storyboard 来组织视图和设置约束。
  • iOS:代码
    可以在 ViewController 中以 命令式 的编程方式设置约束。

在 Android 中通常使用 XML 来写 UI,XML 也是一种声明式,但使用 XML 写 UI,是不能在代码里直接操作 UI,还需要一步 findViewById 的步骤;在 iOS 中通常使用 命令式 的代码来写 UI ,命令式 可以直接在代码里操作 UI,但是要写复杂的界面的时候,就会很痛苦。

Flutter UI 布局的写法

Flutter 写 UI 布局:

  1. 只能用代码来写 UI
  2. 而且 Flutter 用代码写 UI 的方式是声明式的,和其他平台用代码来写 UI 的命令式不同。

为了看出 Flutter 声明式和其他平台命令式的不同,接下来举一个例子说明。

命令式 VS 声明式

假设要实现一个下面的界面:

Flutter 学习(九)Flutter 写 UI 的方式 —— 声明式 - 图1

使用命令式实现

如果用命令式的代码来实现,那么代码就会是这样子的():

  1. // 分别实现各个view
  2. ViewA a = new ViewA(...)
  3. ViewB b = new ViewB(...)
  4. ViewC c1 = new ViewC(...)
  5. ViewC c2 = New ViewC(...)
  6. // 然后将子view 添加到容器中
  7. a.add(b)
  8. b.add(c1)
  9. b.add(c2)

你首先要通过 View 的构造函数创建 View 的实例,然后在组织 View 的层级。

使用声明式实现

用 Flutter 声明式 的代码实现就是这样的:

  1. Widget build(BuildContext context) {
  2. return ViewA{
  3. child: ViewB{
  4. color: yellow,
  5. children: [
  6. ViewC(...),
  7. ViewC(...)
  8. ]
  9. }
  10. }
  11. }

这种方式写 UI,有点类似于 Android 的 XML,声明了 UI 元素之间的关系和嵌套层次,但却是用代码实现的,所以少了 XML 解析的步骤,也使 Flutter UI 构建的效率更高。

Flutter 写 UI

再看之前创建的 Flutter 工程里,用来写 UI 的代码:

  1. Widget build(BuildContext context) {
  2. return MaterialApp(
  3. title: 'Flutter Demo',
  4. theme: ThemeData(
  5. primarySwatch: Colors.blue,
  6. ),
  7. home: Scaffold(
  8. body: Center(
  9. child: GestureDetector(
  10. child: Text(widget.content),
  11. onTap: increment,
  12. )
  13. ),
  14. )
  15. );
  16. }

用代码来写 UI,同时也表现出了 UI 的层级:

Flutter 学习(九)Flutter 写 UI 的方式 —— 声明式 - 图2

参考

【1】Flutter 实战
【2】Flutter 中文文档
【3】Flutter 完全手册