我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Flutter组件状态管理的方法有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Flutter组件状态管理的方法有哪些

这篇文章主要为大家展示了“Flutter组件状态管理的方法有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Flutter组件状态管理的方法有哪些”这篇文章吧。

前言

前面讲了Flutter布局,布局只是静态的。在Flutter中,组件分为StatelesslWidget和StatefulWidget。

  • StatelesslWidget

没有状态,是一成不变的。比如图标,文字,按钮等

  • StatefulWidget

有状态的组件,页面数据是动态的,或者会随着用户操作变化,比如多选框,文本输入框等。

有状态组件

重点来了,如何使用实现一个有状态的组件呢?

  • 有状态的组件一般由两个类构成,一个StatefulWidget子类和一个State子类.

  • State类包含了组件的build()方法,并且负责维护组件状态

  • 当这个组件的状态变化了,可以调用setState()方法来刷新页面

状态管理

由谁来负责状态管理呢?是组件本身,还是他的父类,两者都有又或是其他对象?答案是都可以。也就是说有三种方法实现状态管理:

组件自己管理自己的状态
2.组件的父组件管理状态
3.混搭管理

那么如何决定该用那种方式来进行状态管理呢?一般来讲有以下原则:

如果是用户数据,比如多选框是否被选中,一般是由选择第2种方法
2.如果动效,比如放大缩小,那一般用第1种方法

PS:如果你实在迷芒,就直接选择用第2种方法,用父类管理状态。

举例

组件自己管理自己的状态

如下代码:_TapboxAState这个State子类为TapboxA维护状态,内部定义了一个_active变量来决定当前是否为激活的状态,内部还定义了一个_handleTap()回调函数,来处理用户点击后的逻辑,并且调用了setState()生命周期方法,重新刷新页面。

import 'package:flutter/material.dart';// TapboxA 自己管理状态void main() => runApp(const MyApp());//------------------------- TapboxA ----------------------------------class TapboxA extends StatefulWidget {  const TapboxA({Key? key}) : super(key: key);  @override  _TapboxAState createState() => _TapboxAState();}class _TapboxAState extends State<TapboxA> {  bool _active = false;  void _handleTap() {    setState(() {      _active = !_active;    });  }    @override  Widget build(BuildContext context) {    return GestureDetector(      onTap: _handleTap,      child: Container(        child: Center(          child: Text(            _active ? 'Active' : 'Inactive',            style: const TextStyle(fontSize: 32.0, color: Colors.white),          ),        ),        width: 200.0,        height: 200.0,        decoration: BoxDecoration(          color: _active ? Colors.lightGreen[700] : Colors.grey[600],        ),      ),    );  }}//------------------------- MyApp ----------------------------------class MyApp extends StatelessWidget {  const MyApp({Key? key}) : super(key: key);  @override  Widget build(BuildContext context) {    return MaterialApp(      title: 'Flutter Demo',      home: Scaffold(        appBar: AppBar(          title: const Text('Flutter Demo'),        ),        body: const Center(          child: TapboxA(),        ),      ),    );  }}

父组件管理状态

更多时候我们需要父组件来决定子组件什么时候来更新状态,子组件只需要根据父组件传过来的参数进行合理的展示即可。这种情况下子组件并不需要维护状态,所以子组件是一个StatelessWidget,父组件ParentWidget才是StatefulWidget。代码如下:
父组件维护了一个_active变量用来标记是否为激活状态,并且实现了回调函数_handleTapboxChanged用来反转激活状态,供子组件调用。子组件TapboxB是一个无状态组件,只需要在被点击的时候通知父组件来管理状态。

import 'package:flutter/material.dart';void main() => runApp(const MyApp());class ParentWidget extends StatefulWidget {  const ParentWidget({Key? key}) : super(key: key);  @override  _ParentWidgetState createState() => _ParentWidgetState();}class _ParentWidgetState extends State<ParentWidget> {  bool _active = false;  void _handleTapboxChanged(bool newValue) {    setState(() {      _active = newValue;    });  }  @override  Widget build(BuildContext context) {    return SizedBox(      child: TapboxB(        active: _active,        onChanged: _handleTapboxChanged,      ),    );  }}//------------------------- TapboxB ----------------------------------class TapboxB extends StatelessWidget {  const TapboxB({    Key? key,    this.active = false,    required this.onChanged,  }) : super(key: key);  final bool active;  final ValueChanged<bool> onChanged;  void _handleTap() {    onChanged(!active);  }  @override  Widget build(BuildContext context) {    return GestureDetector(      onTap: _handleTap,      child: Container(        child: Center(          child: Text(            active ? 'Active' : 'Inactive',            style: const TextStyle(fontSize: 32.0, color: Colors.white),          ),        ),        width: 200.0,        height: 200.0,        decoration: BoxDecoration(          color: active ? Colors.lightGreen[700] : Colors.grey[600],        ),      ),    );  }}//------------------------- MyApp ----------------------------------class MyApp extends StatelessWidget {  const MyApp({Key? key}) : super(key: key);  @override  Widget build(BuildContext context) {    return MaterialApp(      title: 'Flutter Demo',      home: Scaffold(        appBar: AppBar(          title: const Text('Flutter Demo'),        ),        body: const Center(//          child: TapboxA(),          child: ParentWidget(),        ),      ),    );  }}

混搭管理

混搭管理状态,就是因为有些情况下我们需要父组件管理一部分状态,子组件独立管理另一部分状态。在本次,我们根据上例添加一个动效,按钮按下时要显示高亮状态(前文讲过,动效一类的状态一般要组件本身管理),抬起时取消高亮。
如下代码:ParentWidget负责维护_active状态来标志是否被激活,子组件TapboxC负责维护_highlight状态用来控制是否高亮显示。

Flutter组件状态管理的方法有哪些

import 'package:flutter/material.dart';void main() => runApp(const MyApp());class ParentWidget extends StatefulWidget {  const ParentWidget({Key? key}) : super(key: key);  @override  _ParentWidgetState createState() => _ParentWidgetState();}class _ParentWidgetState extends State<ParentWidget> {  bool _active = false;  void _handleTapboxChanged(bool newValue) {    setState(() {      _active = newValue;    });  }  @override  Widget build(BuildContext context) {    return SizedBox(      child: TapboxC(        active: _active,        onChanged: _handleTapboxChanged,      ),    );  }}//----------------------------- TapboxC ------------------------------class TapboxC extends StatefulWidget {  const TapboxC({    Key? key,    this.active = false,    required this.onChanged,  }) : super(key: key);  final bool active;  final ValueChanged<bool> onChanged;  @override  _TapboxCState createState() => _TapboxCState();}class _TapboxCState extends State<TapboxC> {  bool _highlight = false;  void _handleTapDown(TapDownDetails details) {    setState(() {      _highlight = true;    });  }  void _handleTapUp(TapUpDetails details) {    setState(() {      _highlight = false;    });  }  void _handleTapCancel() {    setState(() {      _highlight = false;    });  }  void _handleTap() {    widget.onChanged(!widget.active);  }  @override  Widget build(BuildContext context) {    return GestureDetector(      onTapDown: _handleTapDown, // Handle the tap events in the order that      onTapUp: _handleTapUp, // they occur: down, up, tap, cancel      onTap: _handleTap,      onTapCancel: _handleTapCancel,      child: Container(        child: Center(          child: Text(widget.active ? 'Active' : 'Inactive',              style: const TextStyle(fontSize: 32.0, color: Colors.white)),        ),        width: 200.0,        height: 200.0,        decoration: BoxDecoration(          color: _highlight?Colors.lightGreen :widget.active ? Colors.lightGreen[700] : Colors.grey[600],        ),      ),    );  }}//------------------------- MyApp ----------------------------------class MyApp extends StatelessWidget {  const MyApp({Key? key}) : super(key: key);  @override  Widget build(BuildContext context) {    return MaterialApp(      title: 'Flutter Demo',      home: Scaffold(        appBar: AppBar(          title: const Text('Flutter Demo'),        ),        body: const Center(//          child: TapboxA(),          child: ParentWidget(),        ),      ),    );  }}

当然你也可以把高亮显示的状态交给父组件来管理,但是当你开发完这个组件交给同事来用的时候,别人可能只会关注业务逻辑上的处理,不会关注的动效处理。

其他交互组件

Flutter内部预置了很多交互组件,甚至还有IOS风格的组件,都可以拿来用。如果有必要的话,可以向上面的例子一样自定义组件使用。

以上是“Flutter组件状态管理的方法有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Flutter组件状态管理的方法有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Flutter组件状态管理的方法有哪些

这篇文章主要为大家展示了“Flutter组件状态管理的方法有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Flutter组件状态管理的方法有哪些”这篇文章吧。前言前面讲了Flutter布局,
2023-06-29

React状态管理的规则有哪些

React状态管理的规则有哪些,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。No.1 一个关注点有效状态管理的第一个规则是:使状态变量负责一个问题。使状态变量负责一个问题使其符
2023-06-20

查看mysql状态的方法有哪些

有以下几种方法可以查看MySQL的状态:1. 使用命令行工具:可以通过在命令行中执行`mysqladmin status`命令来查看MySQL的状态。该命令会显示MySQL的版本信息、运行时间、并发连接数等。2. 使用MySQL客户端:可以
2023-10-11

Linux用户组管理的方法有哪些

今天小编给大家分享一下Linux用户组管理的方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、增加一个新的用户组使
2023-06-27

Vuex状态管理的方法是什么

这篇文章主要介绍“Vuex状态管理的方法是什么”,在日常操作中,相信很多人在Vuex状态管理的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vuex状态管理的方法是什么”的疑惑有所帮助!接下来,请跟
2023-06-03

vuex状态管理数据状态查询与更改的方法

本篇内容介绍了“vuex状态管理数据状态查询与更改的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!状态管理数据状态查询与更改1.main
2023-06-30

C#改变windows服务状态的方法有哪些

本篇内容主要讲解“C#改变windows服务状态的方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#改变windows服务状态的方法有哪些”吧!C#windows服务状态、启动和停止服
2023-06-18

Pop3协议的处理状态有哪些

本篇内容主要讲解“Pop3协议的处理状态有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Pop3协议的处理状态有哪些”吧!1、基本操作  初始时,服务器通过侦听TCP端口110开始POP3服
2023-06-04

hse管理方法有哪些

hse管理方法主要有:1、风险识别与控制;2、安全经验分享;3、目视化管理;4、作业许可;5、个人安全行动计划;6、高风险控制模型;7、“矩阵式”HSE检查;8、HSE可视化;9、团队式班前会;10、HSE停工授权。HSE可视化是指将HSE数据以图形化的方式展示,以便于人们更好地理解和分析。
hse管理方法有哪些
2023-10-29

golang包管理的方法有哪些

Go语言的包管理主要有以下几种方法:go mod:自从Go 1.11版本引入了go mod,它成为了Go语言默认的包管理工具。go mod会自动下载依赖包,并且将依赖的版本信息保存在go.mod文件中。使用go mod可以方便地管理项目的依
golang包管理的方法有哪些
2024-02-29

CentOS系统中文件管理的方法有哪些

这篇文章主要介绍“CentOS系统中文件管理的方法有哪些”,在日常操作中,相信很多人在CentOS系统中文件管理的方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CentOS系统中文件管理的方法有哪些
2023-06-10

Electron电源状态管理的方法是什么

这篇“Electron电源状态管理的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Electron电源状态管理的方
2023-07-05

React中使用事件驱动进行状态管理的方法

这篇文章给大家分享的是有关React中使用事件驱动进行状态管理的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。自 Hook 被引入 React 以来,Context API 与 Hook 库在应用状态管理中
2023-06-14

Vue之Pinia状态管理的方法是什么

这篇文章主要介绍“Vue之Pinia状态管理的方法是什么”,在日常操作中,相信很多人在Vue之Pinia状态管理的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue之Pinia状态管理的方法是什么
2023-07-05

uniapp组件传值的方法有哪些

这篇文章主要介绍“uniapp组件传值的方法有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“uniapp组件传值的方法有哪些”文章能帮助大家解决问题。父组件给子组件传值创建子组件comp.vue
2023-07-05

C#组件设计的方法有哪些

本篇内容主要讲解“C#组件设计的方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#组件设计的方法有哪些”吧!在C#中为类预定义属性是件再简单不过的事,见程序1。程序1using Sys
2023-06-17

angular组件传值的方法有哪些

Angular组件之间传值的方法有以下几种:输入属性(@Input):在子组件上通过@Input装饰器定义一个输入属性,然后在父组件中通过绑定语法将值传递给子组件。输出属性(@Output)和事件触发:在子组件中通过@Output装饰器定义
2023-10-24

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录