使用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
class Screen3 extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: Text(
Provider.of
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,您可以保存在屏幕之间共享的任何数据,包括计数器、用户数据等等。
下一篇:保留fread中被丢弃的行