行的固定能力由以下条件决定:
固定状态以以下形式存储在表格中:
export type RowPinningPosition = false | 'top' | 'bottom'
export type RowPinningState = {
top?: string[]
bottom?: string[]
}
export type RowPinningRowState = {
rowPinning: RowPinningState
}
export type RowPinningPosition = false | 'top' | 'bottom'
export type RowPinningState = {
top?: string[]
bottom?: string[]
}
export type RowPinningRowState = {
rowPinning: RowPinningState
}
enableRowPinning?: boolean | ((row: Row<TData>) => boolean)
enableRowPinning?: boolean | ((row: Row<TData>) => boolean)
启用/禁用表格中所有行的固定功能。
keepPinnedRows?: boolean
keepPinnedRows?: boolean
当值为 false 时,如果固定行被过滤或分页移出表格,它们将不可见。当值为 true 时,固定行将始终可见,不受过滤或分页影响。默认为 true。
onRowPinningChange?: OnChangeFn<RowPinningState>
onRowPinningChange?: OnChangeFn<RowPinningState>
如果提供此函数,当 state.rowPinning 发生变化时,将调用该函数并传入 updaterFn。这会覆盖默认的内部状态管理,因此您还需要从自己管理的状态中提供 state.rowPinning。
setRowPinning: (updater: Updater<RowPinningState>) => void
setRowPinning: (updater: Updater<RowPinningState>) => void
设置或更新 state.rowPinning 状态。
resetRowPinning: (defaultState?: boolean) => void
resetRowPinning: (defaultState?: boolean) => void
将 rowPinning 状态重置为 initialState.rowPinning,或者可以传递 true 强制重置为默认空状态 {}。
getIsSomeRowsPinned: (position?: RowPinningPosition) => boolean
getIsSomeRowsPinned: (position?: RowPinningPosition) => boolean
返回是否有任何行被固定。可选指定仅检查 top 或 bottom 位置的固定行。
getTopRows: () => Row<TData>[]
getTopRows: () => Row<TData>[]
返回所有固定在顶部的行。
getBottomRows: () => Row<TData>[]
getBottomRows: () => Row<TData>[]
返回所有固定在底部的行。
getCenterRows: () => Row<TData>[]
getCenterRows: () => Row<TData>[]
返回所有未固定在顶部或底部的行。
pin: (position: RowPinningPosition) => void
pin: (position: RowPinningPosition) => void
将行固定在 'top' 或 'bottom',如果传入 false 则取消固定到中间位置。
getCanPin: () => boolean
getCanPin: () => boolean
返回该行是否可以被固定。
getIsPinned: () => RowPinningPosition
getIsPinned: () => RowPinningPosition
返回行的固定位置('top'、'bottom' 或 false)。
getPinnedIndex: () => number
getPinnedIndex: () => number
返回行在固定行组中的数字索引位置。
Your weekly dose of JavaScript news. Delivered every Monday to over 100,000 devs, for free.