Commit 6a5ef29a authored by liyuqian's avatar liyuqian Committed by Flutter GitHub Bot

More clarifications on mutating Widget's children (#46725)

parent d81d9160
...@@ -1729,9 +1729,61 @@ abstract class MultiChildRenderObjectWidget extends RenderObjectWidget { ...@@ -1729,9 +1729,61 @@ abstract class MultiChildRenderObjectWidget extends RenderObjectWidget {
/// The widgets below this widget in the tree. /// The widgets below this widget in the tree.
/// ///
/// If this list is going to be mutated, it is usually wise to put [Key]s on /// If this list is going to be mutated, it is usually wise to put a [Key] on
/// the widgets, so that the framework can match old configurations to new /// each of the child widgets, so that the framework can match old
/// configurations and maintain the underlying render objects. /// configurations to new configurations and maintain the underlying render
/// objects.
///
/// Also, a [Widget] in Flutter is immutable, so directly modifying the
/// [children] such as `someMultiChildRenderObjectWidget.children.add(...)` or
/// as the example code below will result in incorrect behaviors. Whenever the
/// children list is modified, a new list object should be provided.
///
/// ```dart
/// class SomeWidgetState extends State<SomeWidget> {
/// List<Widget> _children;
///
/// void initState() {
/// _children = [];
/// }
///
/// void someHandler() {
/// setState(() {
/// _children.add(...);
/// });
/// }
///
/// Widget build(...) {
/// // Reusing `List<Widget> _children` here is problematic.
/// return Row(children: _children);
/// }
/// }
/// ```
///
/// The following code corrects the problem mentioned above.
///
/// ```dart
/// class SomeWidgetState extends State<SomeWidget> {
/// List<Widget> _children;
///
/// void initState() {
/// _children = [];
/// }
///
/// void someHandler() {
/// setState(() {
/// // The key here allows Flutter to reuse the underlying render
/// // objects even if the children list is recreated.
/// _children.add(ChildWidget(key: ...));
/// });
/// }
///
/// Widget build(...) {
/// // Always create a new list of children as a Widget is immutable.
/// return Row(children: List.from(_children));
/// }
/// }
/// ```
final List<Widget> children; final List<Widget> children;
@override @override
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment