Happy Flutter-StatefulWidget

Dart基本语法学的差不多了以后就可以开始学习Flutter了,就像OC学完了就可以开发iOS一样,触类旁通,Flutter开发需要掌握的基本技能无外乎也是那几个东西,界面布局,网络请求,数据加载,第三方库的使用,学会这些基本可以完成一些简单的Flutter模块的开发了,写文章是为了记录,学习语言最主要的还是得多敲多练,在实战中磨炼才是王道。

StatefulWidget

这次的demo也是一个计数器,理解一下StatefulWidget相关知识点,看效果图:


计数器

功能很简单,点加号和减号当前计数会改变,下面有段文字是从widget传进来的内容,下面是代码:

import 'package:flutter/material.dart';

main(List<String> args) {
  return runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('计数器')
        ),
        body: MyContent('从Widget传进来的内容'),
      ),
    );
  }
}

class MyContent extends StatefulWidget {

  String des;

  MyContent(this.des);

  @override
  _MyContentState createState() => _MyContentState();
}

class _MyContentState extends State<MyContent> {

  var _count = 0;
  
  @override
  Widget build(BuildContext context) {
    return Center(
      child: Column(
        mainAxisAlignment: MainAxisAlignment.center,
        children: [
          Row(
            mainAxisAlignment: MainAxisAlignment.center,
            children: [
              RaisedButton(
                color: Colors.amber,
                child: Text('+'),
                onPressed: () {
                  setState(() {
                    _count++;
                  });
                }
              ),
              RaisedButton(
                child: Text('-'),
                color: Colors.yellowAccent,
                onPressed: () {
                  setState(() {
                    _count--;
                  });
                }
              )
            ],
          ),
          SizedBox(height: 8),
          Text('当前计数$_count',
            style: TextStyle(fontSize: 18)
          ),
          Text(this.widget.des)
        ],
      ),
    );
  }
}

整体结构:

最下面是一个Center,他可以让子widget居中,Center里面放了一个Column,Column第一行是一个Row,Row里面放了两个Text,一个”+“,一个”-“,第二行和第三行都是两个Text,整个结构简单的不能再简单了。

包含的知识点:

  1. Column和Row都有一个主轴和交叉轴的概念,一开始他们两个主轴的对齐方式Column是顶部对齐,Row是左对齐,这个我没看文档,我是看程序效果,说错了别喷我,效果是这样的:


    初始对齐方式

    加号和减号是放在Row当中,可以看到他两个是靠左对齐,整体这个Column里面的三行都是挨着顶部,可以看出来是顶部对齐。

  2. Column和Row可以设置主轴的对齐方式,这个主轴和交叉轴是Flex布局的核心,Row主轴其实就是水平方向,Column主轴就是垂直方向,交叉轴就是和主轴交叉的方向,通过mainAxisAlignment这个属性可以设置主轴的对齐方式,同样的,通过CrossAxisAlignment这个属性可以设置交叉轴的对齐方式。
  3. RaisedButton是一个按钮Widget,这个只是Button的其中一个,具体有啥高级特性还没用到,这个地方主要用到的是他的一个点击事件,接收一个匿名函数作为响应的事件回调函数,类型是void Function() onPressed
  4. StatefulWidget和StatelessWidget不同的地方在于他多了一个State<StatefulWidget> createState()方法,这个方法会返回一个State类型的Widget,State里面有个build方法,关于这个方法有几个介绍:

Describes the part of the user interface represented by this widget.
The framework calls this method in a number of different situations. For example:
After calling [initState].
After calling [didUpdateWidget].
After receiving a call to [setState].
After a dependency of this [State] object changes (e.g., an [InheritedWidget] referenced by the previous [build] changes).
After calling [deactivate] and then reinserting the [State] object into the tree at another location.

build方法返回的Widget也是用户界面展示的一部分,这个方法有很多场景可以触发,在这个例子中是通过setState这个方法来触发的,在‘+’和‘-’按钮的回调里执行了setState方法,让build方法重新执行,刷新界面,展示数据的改变。在这个例子中是count这个变量改变了,在变量和方法前面加''代表是私有的,_count值的改变都会在下一次的build方法中被更新展现。

  1. 在MyContent中还有一个String des;变量,这个地方编译器其实是有一个警告的,它说这个des变量应该定义成final的,因为StatefulWidget和StatelessWidget都继承自Widget,Widget这个类的定义外面有一个@immutable的注解,也就是说这个类中定义的变量都应该是不可变的,如下图:
    Widget定义

这个des变量是定义在Widget中的,但是我在State类中可以直接通过this.widget.des直接获取到这个变量,也就是说State和Widget之间系统为我们提供了一层引用关系,可以让我们方便的使用Widget中的变量,这个绑定关系后面在讲到Flutter中的三课树的时候再具体分析。

  1. 最后一个点就是比较经典的可能面试也会喜欢问到的问题,为啥StatefulWidget的build方法要放在State中还不是放在Widget里,这边第一个可以看到因为你Widget里定义的变量都是final的,都不能改变何来数据的刷新,这是我自己的理解,还有几个是coderwhy的理解,放在这里,不记得原话是啥意思了,后面再慢慢悟吧。

为什么Flutter在设计的时候StatefulWidget的build方法放在State中
1.build出来的Widget是需要依赖State中的变量(状态/数据)
2.在Flutter的运行过程中Widget是不断的销毁和创建的,当我们自己的状态发生改变时,并不希望重新状态一个新的State。

参考资料:
Flutter教程

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容