Flutter有無(wú)狀態(tài)類與State及生命周期詳細(xì)介紹
Flutter中的生命周期類似于Vue、React中的生命周期一樣,有初始化、狀態(tài)更新、停用、銷毀等。
在React中,組件分為函數(shù)式組件和類式組件,它們的區(qū)別就是一個(gè)無(wú)狀態(tài)、一個(gè)有狀態(tài)。那么在Flutter中亦是如此,它有兩種類,一種是無(wú)狀態(tài)類,一種是有狀態(tài)類。其生命周期的使用就是有狀態(tài)類的特定用法。
無(wú)狀態(tài)類
無(wú)狀態(tài)類內(nèi)部有build方法,在表面上看 每次數(shù)據(jù)更新都會(huì)執(zhí)行build方法。但實(shí)際上,在組件樹(shù)中,當(dāng)每次數(shù)據(jù)發(fā)生變更時(shí),無(wú)狀態(tài)類都會(huì)重新執(zhí)行組件LessComponent對(duì)象。
class LessComponent extends StatelessWidget {
const LessComponent({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Container();
}
}有狀態(tài)類
在有狀態(tài)類中,每次的數(shù)據(jù)發(fā)生變動(dòng),在組件樹(shù)中只會(huì)調(diào)用state下的build方法進(jìn)行重新渲染。這時(shí)候就能保存state中的狀態(tài)。
所謂的狀態(tài)就是 state里的屬性。
class FulComponent extends StatefulWidget {
const FulComponent({Key? key}) : super(key: key);
@override
_FulComponentState createState() => _FulComponentState();
}
class _FulComponentState extends State<FulComponent> {
@override
Widget build(BuildContext context) {
return Container();
}
}狀態(tài)
剛才講到,狀態(tài)就是state中的屬性值。下面來(lái)個(gè)示例進(jìn)行講解:
class FulComponent extends StatefulWidget {
const FulComponent({Key? key}) : super(key: key);
@override
_FulComponentState createState() => _FulComponentState();
}
class _FulComponentState extends State<FulComponent> {
int count = 0;
static const sum = 10;
final nowDate = new DateTime.now();
@override
Widget build(BuildContext context) {
return Container(
child: Column(
children: [
Text('${sum}'),
ElevatedButton.icon(
onPressed: () {
setState(() {
count++;
});
},
icon: Icon(Icons.add),
label: Text('添加')
)
],
),
);
}
}例如 整型值count、常量 sum、當(dāng)前時(shí)間。這都是屬于狀態(tài)值,它們存在的區(qū)別就是count可以通過(guò)setSatate進(jìn)行改變。
當(dāng)每次執(zhí)行setState()時(shí),此組件都會(huì)調(diào)用build方法進(jìn)行將改變的數(shù)據(jù)進(jìn)行重新渲染,以此來(lái)保證state中的屬性值的保存。
State生命周期

class FulComponent extends StatefulWidget {
const FulComponent({Key? key}) : super(key: key);
@override
_FulComponentState createState() => _FulComponentState();
}
class _FulComponentState extends State<FulComponent> {
int count = 0;
static const sum = 10;
final nowDate = new DateTime.now();
@override
void initState() { // 初始化生命周期鉤子
super.initState();
//初始化操作 在這里做
}
@override
void didChangeDependencies() {
super.didChangeDependencies();
// 依賴發(fā)生變更時(shí) 執(zhí)行
}
@override
void reassemble() {
super.reassemble();
// 重新安裝時(shí)執(zhí)行,一般在調(diào)試的時(shí)候用,在發(fā)正式版本時(shí) 不會(huì)執(zhí)行
}
@override
void didUpdateWidget(covariant FulComponent oldWidget) {
super.didUpdateWidget(oldWidget);
// 組件發(fā)生變更時(shí)調(diào)用,當(dāng)父組件有變動(dòng),子組件也會(huì)執(zhí)行此方法
}
@override
void deactivate() {
super.deactivate();
// 停用
}
@override
void dispose() {
super.dispose();
// 銷毀
}
@override
Widget build(BuildContext context) {
return Container(
child: Column(
children: [
Text('${sum}'),
ElevatedButton.icon(
onPressed: () {
setState(() {
count++;
});
},
icon: Icon(Icons.add),
label: Text('添加')
)
],
),
);
}
}到此這篇關(guān)于Flutter有無(wú)狀態(tài)類與State及生命周期詳細(xì)介紹的文章就介紹到這了,更多相關(guān)Flutter狀態(tài)類內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android獲取所在時(shí)區(qū)時(shí)間的兩種方式
Android獲取所在時(shí)區(qū)正確時(shí)間的方式有兩種,通過(guò)wifi獲取時(shí)間和通過(guò)通過(guò)GPS獲取時(shí)間這兩種方式,文中通過(guò)代碼示例給大家的介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04
Android Studio導(dǎo)入Project與Module的方法及實(shí)例
這篇文章主要介紹了Android Studio導(dǎo)入Project與Module的方法及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-04-04
Android重寫(xiě)View并自定義屬性實(shí)例分析
這篇文章主要介紹了Android重寫(xiě)View并自定義屬性的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Android基于重寫(xiě)View實(shí)現(xiàn)自定義屬性的相關(guān)布局與具體技巧,需要的朋友可以參考下2016-02-02
Android程序開(kāi)發(fā)之使用Design包實(shí)現(xiàn)QQ動(dòng)畫(huà)側(cè)滑效果和滑動(dòng)菜單導(dǎo)航
這篇文章主要介紹了Android程序開(kāi)發(fā)之使用Design包實(shí)現(xiàn)QQ動(dòng)畫(huà)側(cè)滑效果和滑動(dòng)菜單導(dǎo)航的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07
Android Studio preview 不固定及常見(jiàn)問(wèn)題的解決辦法
preview 可以幫助您預(yù)覽您的布局文件將如何在用戶的設(shè)備上呈現(xiàn)。這篇文章主要介紹了Android Studio preview 不固定及常見(jiàn)問(wèn)題的解決辦法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-05-05
android 獲取本機(jī)的IP地址和mac物理地址的實(shí)現(xiàn)方法
本文主要介紹android 獲取本機(jī)的IP地址和mac物理地址的實(shí)現(xiàn)方法,這里提供示例代碼,實(shí)現(xiàn)功能,有需要的小伙伴可以參考下2016-09-09
Kotlin實(shí)現(xiàn)在類里面創(chuàng)建main函數(shù)
這篇文章主要介紹了Kotlin實(shí)現(xiàn)在類里面創(chuàng)建main函數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-03-03
Android Studio實(shí)現(xiàn)音樂(lè)播放器
這篇文章主要為大家詳細(xì)介紹了Android Studio實(shí)現(xiàn)音樂(lè)播放器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11

