想跳过实现步骤?查看这些示例
TanStack Table 提供了状态和 API,有助于在表格 UI 中实现列固定功能。您可以通过多种方式实现列固定。您可以将固定的列拆分到它们自己的单独表格中,或者您可以将所有列保留在同一表格中,但使用固定状态来正确排序这些列,并使用粘性 CSS 将列固定到左侧或右侧。
有 3 个表格功能可以重新排序列,它们按以下顺序发生
更改固定列顺序的唯一方法是在 columnPinning.left 和 columnPinning.right 状态本身中。columnOrder 状态只会影响未固定(“中间”)列的顺序。
管理 columnPinning 状态是可选的,通常不是必要的,除非您要添加持久状态功能。TanStack Table 已经为您跟踪列固定状态。如果您需要,可以像管理任何其他表格状态一样管理 columnPinning 状态。
const [columnPinning, setColumnPinning] = useState<ColumnPinningState>({
left: [],
right: [],
});
//...
const table = useReactTable({
//...
state: {
columnPinning,
//...
}
onColumnPinningChange: setColumnPinning,
//...
});
const [columnPinning, setColumnPinning] = useState<ColumnPinningState>({
left: [],
right: [],
});
//...
const table = useReactTable({
//...
state: {
columnPinning,
//...
}
onColumnPinningChange: setColumnPinning,
//...
});
一个非常常见的用例是默认固定某些列。您可以通过使用固定的 columnIds 初始化 columnPinning 状态,或者使用 initialState 表格选项来完成此操作
const table = useReactTable({
//...
initialState: {
columnPinning: {
left: ['expand-column'],
right: ['actions-column'],
},
//...
}
//...
});
const table = useReactTable({
//...
initialState: {
columnPinning: {
left: ['expand-column'],
right: ['actions-column'],
},
//...
}
//...
});
注意:其中一些 API 在 v8.12.0 中是新增的
有一些有用的 Column API 方法可以帮助您实现列固定功能
如果您只是使用粘性 CSS 来固定列,那么在大多数情况下,您可以像往常一样使用 table.getHeaderGroups 和 row.getVisibleCells 方法渲染表格。
但是,如果您要将固定的列拆分到它们自己的单独表格中,则可以使用 table.getLeftHeaderGroups、table.getCenterHeaderGroups、table.getRightHeaderGroups、row.getLeftVisibleCells、row.getCenterVisibleCells 和 row.getRightVisibleCells 方法,仅渲染与当前表格相关的列。
您的每周 JavaScript 新闻。每周一免费发送给超过 100,000 名开发者。