1# Improving Layout Performance 2 3 4When you are using the **\<Flex>** component, note that its layout performance may drop in certain scenarios. The **\<Flex>** component is a container whose child components are automatically laid out to create a flexible layout. By default, the child components are arranged along the main axis. The size of a child component along the main axis is called its main axis size. 5 6 7In the single-row layout scenario, if the total main axis length of child components is not equal to the main axis length of the container, some child components are laid out twice to fill the container, that is, secondary layout is required. As a result, the layout efficiency decreases. 8 9 10## Scenario 1 11 12The **DisplayPriority** or **LayoutWeight** attribute of all child components is set to their default value or is not set. In this scenario, the child components are all laid out in sequence. 13 14 15- If the total main axis length of the child components is equal to the main axis length of the container in the first layout, no secondary layout is required. 16 ![layout-performance-1](figures/layout-performance-1.png) 17 18- If the total main axis length of the child components is less than the main axis length of the container in the first layout, the child components with valid **flexGrow** values will trigger secondary layout and be stretched to fill the container. 19 ![layout-performace-2](figures/layout-performace-2.gif) 20 21- If the total main axis length of the child components is greater than the main axis length of the container in the first layout, the child components with valid **flexShrink** (whose default value **1** is valid) values will trigger secondary layout and shrink to fill the container. 22 ![layout-performace-3](figures/layout-performace-3.gif) 23 24 25## Scenario 2 26 27The **DisplayPriority** attribute is set for the child component, but not the **LayoutWeight** attribute. 28 29 30In this scenario, the child components with the same **DisplayPriority** value are laid out in groups, in descending order of the **DisplayPriority** values. When the total main axis length of the child components reaches the maximum and does not exceed the main axis length of the container, child components that have not been laid out and have the smallest **DisplayPriority** value will be discarded (a set of child components with critical **DisplayPriority** values may be laid out but still be discarded). 31 32 33- If the total main axis length of the child components is equal to the main axis length of the container in the first layout, no secondary layout is required. 34 ![layout-performance-4](figures/layout-performance-4.png) 35 36- If the total main axis length of the child components is less than the main axis length of the container in the first layout, the child components with valid **flexGrow** values will trigger secondary layout and be stretched to fill the container. 37 ![layout-performace-5](figures/layout-performace-5.gif) 38 39 40## Scenario 3 41 42The **LayoutWeight** attribute is set for the child component. 43 44In this scenario, the child components with the same **DisplayPriority** value and without the **LayoutWeight** attribute set are laid out in groups, in descending order of the **DisplayPriority** values. When the total main axis length of the child components reaches the maximum and does not exceed the main axis length of the container, child components that have not been laid out and have the smallest **DisplayPriority** value will be discarded (a set of child components with critical **DisplayPriority** values may be laid out but still be discarded). 45 46 47The remaining space in the container is filled by child components for which the **LayoutWeight** attribute is set. 48 49 50- The child components are laid out only once in this process, and secondary layout is not triggered. 51 ![layout-performace-6](figures/layout-performace-6.gif) 52 53 54## How to Optimize Flex Layout Performance 55 56- Use **\<Column>** and **\<Row>** instead of **\<Flex>**. 57 58- Set the **flexShrink** attribute of child components whose size does not need to be changed to **0**. 59 60- Prioritize the **LayoutWeight** attribute over the **flexGrow** and **flexShrink** attributes. 61 62- Use the most common layout result so that the total main axis length of child components is equal to the main axis length of the **\<Flex>** container. 63