保留Flutter中变量的值并在导航时使用
创始人
2024-11-24 10:31:28
0

使用Provider库

使用Provider库可以在应用程序的各个部分中共享数据。在导航时,要传递给下一个屏幕的数据可以通过将其包装在Provider中来保存。当下一个屏幕被创建时,它可以获取之前屏幕中的Provider中的数据。

以下是使用Provider库的示例代码:

在您的应用程序的顶部添加依赖:

dependencies: flutter: sdk: flutter provider: ^4.3.1

然后,在您的屏幕中:

class Screen1 extends StatelessWidget { @override Widget build(BuildContext context) { return Scaffold( body: Center( child: RaisedButton( child: Text('Go to Screen 2'), onPressed: () { Navigator.push( context, MaterialPageRoute( builder: (context) => Screen2(), ), ); }, ), ), ); } }

class Screen2 extends StatelessWidget { @override Widget build(BuildContext context) { return Scaffold( body: Center( child: RaisedButton( child: Text('Next'), onPressed: () { Provider.of(context, listen: false).increment(); Navigator.push( context, MaterialPageRoute( builder: (context) => Screen3(), ), ); }, ), ), ); } }

class Screen3 extends StatelessWidget { @override Widget build(BuildContext context) { return Scaffold( body: Center( child: Text( Provider.of(context, listen: false).value.toString(), style: Theme.of(context).textTheme.headline4, ), ), ); } }

class MyData with ChangeNotifier { int _value = 0; int get value => _value;

void increment() { _value++; notifyListeners(); } }

在这个例子中,Screen1将跳转到Screen2。Screen2将使用Provider来包装MyData,以便可以在下一个屏幕中访问该数据。当用户按下'下一步”按钮时,MyData的值将递增,并导航到Screen3。在Screen3中,MyData的值将使用Provider.of调用,从先前屏幕中获取。

使用Provider,您可以保存在屏幕之间共享的任何数据,包括计数器、用户数据等等。

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...