initState()
函数是在组件渲染之前执行的。在Flutter中,initState()
是StatefulWidget
的生命周期方法之一,在调用build()
方法之前被调用。- 当创建一个
StatefulWidget
并将其添加到组件树中时,Flutter会实例化该组件的状态对象,并在调用initState()
方法后再调用build()
方法来构建UI。 initState()
通常用于执行一些初始化操作,比如数据获取、订阅事件、启动定时器等。它只会被调用一次,在组件的整个生命周期中只执行一次。- 一旦
initState()
被调用并完成后,就会立即调用build()
方法来构建UI。所以,如果你希望在UI构建之前执行某些操作,可以放在initState()
中。 - 值得注意的是,在
initState()
中不要执行耗时的操作或阻塞UI线程的操作,因为这可能导致应用程序卡顿。如果需要进行异步操作,可以使用Future
、async/await
等方式来处理。 setState()
方法不会触发initState()
的重新执行。当调用setState()
时,它会通知Flutter框架重新构建相关的组件树,并调用build()
方法来更新UI。initState()
方法只在初始化组件时调用一次,在组件的整个生命周期中不会再次执行。它主要用于执行一些初始化操作,比如数据获取、订阅事件、启动定时器等。- 当你调用
setState()
方法后,Flutter会检测到状态发生了变化,并执行与该组件相关的build()
方法来生成新的UI。在build()
方法中,你可以使用新的状态值进行UI渲染。 - 所以,当你在
setState()
中更新了状态数据后,Flutter将会重新构建相关的组件,但不会重新执行initState()
方法。initState()
只会在组件初始创建时被调用一次。
关于flutter中 initState() 与 setState() 用法
Jushden2023-08-29 10:23
相关推荐
君蓦3 小时前
Flutter 本地存储与数据库的使用和优化problc13 小时前
Flutter中文字体设置指南:打造个性化的应用体验lqj_本人21 小时前
鸿蒙next选择 Flutter 开发跨平台应用的原因lqj_本人1 天前
Flutter&鸿蒙next 状态管理框架对比分析起司锅仔1 天前
Flutter启动流程(2)hello world smile1 天前
最全的Flutter中pubspec.yaml及其yaml 语法的使用说明lqj_本人1 天前
Flutter 的 Widget 概述与常用 Widgets 与鸿蒙 Next 的对比iFlyCai1 天前
极简实现酷炫动效:Flutter隐式动画指南第二篇之一些酷炫的隐式动画效果lqj_本人1 天前
Flutter&鸿蒙next 中使用 MobX 进行状态管理