【问题标题】:How to force initState every time the page is rendered in flutter?每次页面以颤振呈现时如何强制initState?
【发布时间】:2021-09-11 08:09:08
【问题描述】:

我正在将一些数据添加到我的应用程序的第 2 页上的SharedPreferences,并且我正在尝试检索主页上的数据。我在第 1 页使用了一个初始化函数,如下所示:

  @override
  void initState() {
    super.initState();
    

    _getrecent();
  }

  void _getrecent() async {
    final prefs = await SharedPreferences.getInstance();
    // prefs.clear();
    String b = prefs.getString("recent").toString();
    Map<String, dynamic> p = json.decode(b);

    if (b.isNotEmpty) {
      print("Shared pref:" + b);
      setState(() {
        c = Drug.fromJson(p);
      });
      cond = true;
    } else {
      print("none in shared prefs");
      cond = false;
    }
  }

由于initState() 只加载一次,我想知道是否有办法在每次呈现 page1 时加载它。或者也许有更好的方法来做到这一点。我是 Flutter 新手,所以我对状态管理没有太多了解。

【问题讨论】:

    标签: flutter dart statefulwidget flutter-state


    【解决方案1】:

    您可以覆盖didChangeDependencies 方法。当您使用 setState 时 [State] 对象的依赖项发生变化时调用,

    @override
      void didChangeDependencies() {
    // your codes
    }
    

    此外,您应该知道使用setState 会更新整个小部件,这会产生开销。为了避免这种情况,您应该 const,声明一个小部件 const 只会呈现一次,因此它很有效。

    【讨论】:

      【解决方案2】:

      首先,您不能强制initState 重建您的小部件。 为此,您有 setState 来重建您的小部件。尽我所能 了解您想召回initState 只需致电_getrecent() 再次。

      理想情况下,您应该这样做:

      一个简单的解决方案是使用FutureBuilder。您只需要在FutureBuilder 中使用_getrecent() 作为您想要使用从_getrecent() 获得的数据的父级。这样,每次您的 Widget 重建时,它都会调用 _getrecent()

      【讨论】:

      • 我是否应该将_getrecent() 的返回类型更改为void 以外的其他类型?
      • 正如我在您分享的代码中看到的那样,您在小部件的某处使用了 c = Drug.fromJson(p); 值。理想情况下,您应该返回此值并将 FutureBuilder 包装到需要此值的小部件。
      【解决方案3】:

      init function 最初只会渲染一次,以避免这种情况 -

      您可以使用setState( ) 方法重新渲染整个小部件。

      【讨论】:

        【解决方案4】:

        如果您想更新小部件,只需使用 setState() 方法即可。这是https://api.flutter.dev/flutter/widgets/State/setState.html的文档

        【讨论】:

          猜你喜欢
          • 2021-06-15
          • 1970-01-01
          • 2013-01-01
          • 1970-01-01
          • 2020-01-10
          • 1970-01-01
          • 2019-01-16
          • 1970-01-01
          • 2023-04-01
          相关资源
          最近更新 更多