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

Flutter怎么交互并使用小工具管理其状态widget的state

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

Flutter怎么交互并使用小工具管理其状态widget的state

这篇文章主要介绍“Flutter怎么交互并使用小工具管理其状态widget的state”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Flutter怎么交互并使用小工具管理其状态widget的state”文章能帮助大家解决问题。

交互

当小部件的状态发生变化时,状态对象调用setState()来告诉框架重新绘制小部件 创建一个自定义的有状态小部件。将用一个自定义的有状态小部件替换两个无状态小部件-红色实心星形图标及其旁边的数字计数-小部件管理一行,其中包含两个子小部件:IconButton和Text。

class FavoriteWidget extends StatefulWidget {  @override  _FavoriteWidgetState createState() => new _FavoriteWidgetState();}

要创建自定义的有状态小部件,需要创建两个类:StatefulWidget和State state对象包含小部件的状态和build()方法。

要实现自定义有状态小部件,需要创建两个类: 定义从StatefulWidget继承的小部件类 包含小部件状态并定义小部件build()方法的类。它继承自State 本节介绍如何为Lakes应用程序构建名为FavoriteWidget的有状态Widget。第一步是选择如何管理FavoriteWidgets的状态。

步骤1:确定哪个对象管理小部件的状态 小部件的状态可以通过多种方式进行管理,但在我们的示例中,小部件本身(FavoriteWidget)将管理自己的状态。在本例中,切换星形图标是一个独立的操作,不会影响父窗口小部件或其他用户界面,因此小部件可以在内部处理自己的状态。

步骤2:创建StatefulWidget的子类 FavoriteWidget类管理自己的状态,因此它重写createState()以创建状态对象。框架在构建小部件时调用createState()。createState()创建了FavoriteWidgetState的一个实例,将在下一步中实现它。

new Icon(  Icons.star,  color: Colors.red[500],),new Text('41')

小工具管理其状态

有时,小部件最好在内部管理其状态。例如,当ListView的内容超过渲染框时,ListView会自动滚动。大多数使用ListView的开发人员不希望管理ListView的滚动行为,因此ListView本身管理其滚动偏移。

class TapboxA extends StatefulWidget {  TapboxA({Key key}) : super(key: key);  @override  _TapboxAState createState() => new _TapboxAState();}class _TapboxAState extends State<TapboxA> {  bool _active = false;  void _handleTap() {    setState(() {      _active = !_active;    });  }  Widget build(BuildContext context) {    return new GestureDetector(      onTap: _handleTap,      child: new Container(        child: new Center(          child: new Text(            _active ? 'Active' : 'Inactive',            style: new TextStyle(fontSize: 32.0, color: Colors.white),          ),        ),        width: 200.0,        height: 200.0,        decoration: new BoxDecoration(          color: _active ? Colors.lightGreen[700] : Colors.grey[600],        ),      ),    );  }}

_TapboxAState类: 管理TapboxA的状态 Definition_Active:确定框当前颜色的布尔值 定义_当框被单击时,handleTap()函数会更新,并调用setState()更新UI

widget的state

实现小部件的所有交互行为 对于父窗口小部件,管理状态并告诉其子窗口小部件何时更新通常是最有意义的。例如,IconButton允许将图标视为可单击的按钮。IconButton是一个无状态小部件,因为我们认为父小部件需要知道按钮是否被单击以采取相应的操作。 在下面的示例中,TapboxB通过回调将其状态导出到其父级。因为TapboxB不管理任何状态,所以它的父类是StatelessWidget。

ParentWidgetState类: 管理TapboxB_活动状态 Implementation_ HandleTapboxChanged(),单击框时调用的方法 当状态更改时,调用setState()更新UI TapboxB类: 继承StatelessWidget类,因为所有状态都由其父控件处理 当检测到单击时,它会通知父控件

class ParentWidget extends StatefulWidget {  @override  _ParentWidgetState createState() => new _ParentWidgetState();}class _ParentWidgetState extends State<ParentWidget> {  bool _active = false;  void _handleTapboxChanged(bool newValue) {    setState(() {      _active = newValue;    });  }  @override  Widget build(BuildContext context) {    return new Container(      child: new TapboxB(        active: _active,        onChanged: _handleTapboxChanged,      ),    );  }}

混合管理

class ParentWidget extends StatefulWidget {  @override  _ParentWidgetState createState() => new _ParentWidgetState();}class _ParentWidgetState extends State<ParentWidget> {  bool _active = false;  void _handleTapboxChanged(bool newValue) {    setState(() {      _active = newValue;    });  }  @override  Widget build(BuildContext context) {    return new Container(      child: new TapboxC(        active: _active,        onChanged: _handleTapboxChanged,      ),    );  }}

对于某些小部件,mashup管理方法是最有意义的。在这种情况下,有状态小部件管理一些状态,而父小部件管理其他状态。 在TapboxC示例中,单击时,框周围会出现一个深绿色边框。单击时,边框将消失,框的颜色将更改。TapboxC将_活动状态导出到其父控件,但内部管理_突出显示状态。此示例有两个状态对象_PrentWidgetState和_TapboxCState

class _TapboxCState extends State<TapboxC> {  bool _highlight = false;  void _handleTapDown(TapDownDetails details) {    setState(() {      _highlight = true;    });  }

ParentWidgetState对象: 管理_活动状态 Implementation HandleTapboxChanged(),单击该框时调用 当单击框并_调用setState()以在活动状态更改时更新UI时 _TapboxCState对象: 管理_突出显示状态。 手势检测器监听所有敲击事件。当用户单击时,它会添加高亮显示(深绿色边框);当用户释放时,高亮显示将被删除。 按下、抬起或取消时更新突出显示状态,调用setState()更新UI。 单击时,状态更改将传递给父控件

  void _handleTapUp(TapUpDetails details) {    setState(() {      _highlight = false;    });  }  void _handleTapCancel() {    setState(() {      _highlight = false;    });  }

另一个实现可能会在保持活动状态的同时将突出显示的状态导出到父窗口小部件。活动状态是内部的,但如果你要求某人使用TapBox,他们可能会抱怨这没有多大意义。开发人员只关心盒子是否处于活动状态。开发人员可能不关心突出显示是如何管理的,而是倾向于让TapBox处理这些细节。

关于“Flutter怎么交互并使用小工具管理其状态widget的state”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

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

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

Flutter怎么交互并使用小工具管理其状态widget的state

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

下载Word文档

猜你喜欢

Flutter怎么交互并使用小工具管理其状态widget的state

这篇文章主要介绍“Flutter怎么交互并使用小工具管理其状态widget的state”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Flutter怎么交互并使用小工具管理其状态widget的stat
2023-07-04

Flutter交互并使用小工具管理其状态widget的state详解

这篇文章主要为大家介绍了Flutter交互并使用小工具管理其状态widget的state详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-12-23

编程热搜

  • 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动态编译

目录