gpt4 book ai didi

parameters - Flutter:将传递的参数更改为 "StatefulWidget"

转载 作者:IT王子 更新时间:2023-10-29 06:53:10 28 4
gpt4 key购买 nike

我有一个名为 BounceContainerStatefulWidget。此类包含一个参数 child ,就像典型的 Flutter 小部件一样。基本上,只要用户点击它,它就会弹出 child 。我现在传递 child 参数的方式如下:

class BounceContainer extends StatefulWidget {
final Widget child; // Declaring "child"
BounceContainer({this.child}); // Initializing "child"

// Passing "child" to State

@override
_BounceContainerState createState() => _BounceContainerState(this.child);
}

class _BounceContainerState extends State<BounceContainer> {
Widget child;
_BounceContainerState(this.child); // Receiving "child"

@override
Widget build(BuildContext context) {
...
}
}

在这种情况下,问题是即使 child 参数发生变化,child 本身也不会更新。

例如,如果我有一个按钮,其颜色根据 AnimationController 从灰色变为任何随机颜色,并且我将此按钮作为 child 参数传递给 BounceContainer 类,按钮仍然保持灰色并调用 setState()(来自主程序或 BounceContainer 类)也不会强制更新 child 小部件。

解决此问题的正确方法(也是有效方法)是什么?

最佳答案

您不需要将所有参数都传递给 State 类。您可以使用 widget.child

访问它们

关于parameters - Flutter:将传递的参数更改为 "StatefulWidget",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56245553/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com