页面状态保持

本文详细介绍如何在Flutter中实现页面状态保持,通过使用AutomaticKeepAliveMixIn和设置wantKeepAlive为true,确保页面在切换时不丢失当前状态。示例代码展示了在TabBarView和PageView中如何正确应用这一机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

状态保持需要做到以下两点:
1:with AutomaticKeepAliveMixIn
2:@override
  bool get wantKeepAlive=>true;



完整示例:
main.dart:
import 'package:flutter/material.dart';

import 'pageview.dart';

void main()=>runApp(MyApp());

class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: HomePage(),
);
}
}

class HomePage extends StatefulWidget {
@override
_HomePageState createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> with SingleTickerProviderStateMixin{
TabController _tabController;
@override
void initState() {
// TODO: implement initState
_tabController=TabController(length: 3, vsync: this);
super.initState();
}
@override
void dispose() {
// TODO: implement dispose
_tabController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('AutomaticKeepAlive'),
bottom: TabBar(
controller: _tabController,
tabs: <Widget>[
Tab(icon: Icon(Icons.send),text: 'send',),
Tab(icon: Icon(Icons.event),text: 'event',),
Tab(icon: Icon(Icons.map),text: 'map',),
],
),
),
body: TabBarView(
controller: _tabController,
children: <Widget>[
PageViewWidget(index:6),
PageViewWidget(index:5),
PageViewWidget(index:3),
],
),

);
}
}




pageview.dart:
import 'package:flutter/material.dart';

import 'dart:ui';

class PageViewWidget extends StatefulWidget {
int index=0;
PageViewWidget({Key key,@required this.index}):super(key:key);
@override
_PageViewWidgetState createState() => _PageViewWidgetState();
}

class _PageViewWidgetState extends State<PageViewWidget> with AutomaticKeepAliveClientMixin{
int count=0;
@override
bool get wantKeepAlive=>true;

@override
Widget build(BuildContext context) {
return Container(
width: window.physicalSize.width,
height: window.physicalSize.height,
child: Stack(
children: <Widget>[
Image.network('http://www.ecobentech.com/images/${widget.index}.jpg',fit: BoxFit.cover,width: window.physicalSize.width,),
Positioned(
top: 200,
left: 60,
child: ActionChip(label: Text('$count'), onPressed:(){
setState(() {
count++;
});
}),
)
],
),
);
}
}


转载于:https://www.cnblogs.com/braveheart007/p/10841557.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值