【问题标题】:How to update StateFullWidget from stateLessWidget如何从 stateLessWidget 更新 StateFullWidget
【发布时间】:2021-04-03 05:03:22
【问题描述】:

我想更新evaluateAnswer bool 并在按下SubmitExamButton(这是一个无状态小部件)按钮时用新值重建QuestionsList(有状态)小部件。但它总是使用我初始化变量的false 值构建它。我尝试使用SubmitExamButton 使Body 有状态小部件看起来像这样:

SubmitExamButton(
    onPress: () {
       setState(() {
           evaluateAnswer = true;
       });
    },
),

Body.dart

class Body extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    bool evaluateAnswer = false;
    return Stack(

      children: [
        Padding(
          child: QuestionsList(
            evaluate: evaluateAnswer,
          ),
        ),
        Positioned(
          bottom: 0,
          child: Container(
            height: 80,
            decoration: BoxDecoration(color: Colors.white),
            width: SizeConfig.screenWidth,
            child: SubmitExamButton(
                onPress: () {
                  evaluateAnswer = true;
                },
              ),
            ),
          ),
        ),
      ],
    );
  }
}

【问题讨论】:

  • 以上代码为简化版

标签: android flutter dart statefulwidget statelesswidget


【解决方案1】:

您需要将evaluateAnswer 移出到与StatefulWidget 关联的State 类的成员变量中。然后,当您在 State 类的 build() 中的任何位置设置State 时,Stateful 小部件将重建。将数据粘贴为无状态小部件的成员数据不会引起重建机制注意到的变化。

【讨论】:

  • 我真的不明白...你能不能用一些代码来说明它或给我链接让我可以阅读更多关于它的信息
  • 大部分“Stateless vs Stateful Widget”教程都在讨论这个问题。对该主题进行谷歌视频搜索。
猜你喜欢
  • 2021-12-14
  • 1970-01-01
  • 2019-03-26
  • 2021-05-16
  • 2020-10-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-08-25
相关资源
最近更新 更多