Flutter-web:浏览器刷新时提供程序丢失状态

标签 flutter provider flutter-web

所以我想知道为什么提供者在浏览器刷新时会丢失状态。刷新/重新加载后不应该保持状态吗?

Would Really appreciate the Help

default project for flutter

home: ChangeNotifierProvider<Counter>(
      create: (_) => Counter(),
      child: MyHomePage(title: 'Flutter Demo Home Page')),



 class MyHomePage extends StatelessWidget {
  final String title;
  MyHomePage({this.title});

  @override
  Widget build(BuildContext context) {
    final counter = Provider.of<Counter>(context);
    return Scaffold(
      appBar: AppBar(
        title: Text(title),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text(
              'You have pushed the button this many 
               times:',
            ),
            Text(
              '${counter.value}',
              style: 
             Theme.of(context).textTheme.headline4,
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: () => counter.increment(),
        tooltip: 'Increment',
        child: Icon(Icons.add),
      ), 
    );
  }
}

Here's the Provider Class

import 'package:flutter/foundation.dart';

    class Counter with ChangeNotifier {
      
      int value=0;
      void increment() {
        
        value++;
        notifyListeners();
      }
    }

最佳答案

您可以使用 cookie 或跟踪状态和其他信息。我找到了这段代码,即使在刷新时也能工作。

import 'package:universal_html/html.dart' as html;

class CookieManager {

  static addToCookie(String key, String value) {
     // 2592000 sec = 30 days.
     html.document.cookie = "$key=$value; max-age=2592000; path=/;";
  }

  static String getCookie(String key) {

    String cookies = html.document.cookie;
    List<String> listValues = cookies.isNotEmpty ? cookies.split(";") : List();
    String matchVal = "";
    for (int i = 0; i < listValues.length; i++) {
      List<String> map = listValues[i].split("=");
      String _key = map[0].trim();
      String _val = map[1].trim();
      if (key == _key) {
        matchVal = _val;
        break;
      }
    }
    return matchVal;
  }
}

关于Flutter-web:浏览器刷新时提供程序丢失状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61232367/

相关文章:

flutter - 让 Dart 类公开,但构造函数私有(private)

flutter - 如何将示例项目添加到 Flutter 包中?

flutter - 对多个页面使用相同的 riverpod 状态提供程序

flutter - 防止未经身份验证的用户使用 Flutter Web 应用程序中的 URL 导航到路由?

android - Flutterfire 配置无法以任何可能的方式工作

flutter - 用两个ord​​erBy()排序数据不起作用(Flutter)

c# - 将自定义属性添加到 app.config 中的自定义提供程序配置部分

firebase - Flutter Provider显示来自错误用户的数据

Flutter web 轻松打印

flutter-web - 如何让文件被选中