ant-design Dynamic row adjustment

iyr7buue  于 3个月前  发布在  其他
关注(0)|答案(4)|浏览(40)

What problem does this feature solve?

In Ant Design tables with large datasets and pagination, the pagination component can appear:

  • Misplaced: Ending with empty space below the table when there's room for more rows.
  • Overflowing: Pushing content below the table viewport when space is limited.

What does the proposed API look like?

Proposed Solution:

Implement a new feature for the Table component that dynamically adjusts the number of displayed rows based on available space in the parent container. This can be achieved using the useRef hook in React to get the table's height and the parent container's viewport height.

Implementation:

  • Introduce a new prop for the Table component, for example, dynamicRowAdjustment . This prop can be a boolean, by default it will be false
  • Utilize useRef to create a reference to the table element. Within the component lifecycle methods (e.g., componentDidMount or componentDidUpdate), calculate the available space in the parent container by subtracting the table's height from the viewport height.
  • Based on the available space and a configurable threshold (e.g., minimum row height), adjust the number of rows displayed in the table. This could involve modifying the pageSize prop of the pagination or manipulating the data source directly.
7xzttuei

7xzttuei1#

Willing to work on it as well. :)

vdgimpew

vdgimpew2#

What's the API look like?

hzbexzde

hzbexzde3#

@zombieJ it will only add one more prop to the table, called dynamicRowAdjustment . Everything will be handled under the hood!!

If it is set to true , we will do our magic. By default it will be set to false , so it won't effect any older codebases.

zpgglvta

zpgglvta4#

Can I work on this one? It would be awesome if you could assign me to this.

Thanks

相关问题