enableRowSelection
enableMultiRowSelection
enableSubRowSelection
onRowSelectionChange
getToggleAllRowsSelectedHandler
getToggleAllPageRowsSelectedHandler
setRowSelection
resetRowSelection
getIsAllRowsSelected
getIsAllPageRowsSelected
getIsSomeRowsSelected
getIsSomePageRowsSelected
toggleAllRowsSelected
toggleAllPageRowsSelected
getPreSelectedRowModel
getSelectedRowModel
getFilteredSelectedRowModel
getGroupedSelectedRowModel
getIsSelected
getIsSomeSelected
getIsAllSubRowsSelected
getCanSelect
getCanMultiSelect
getCanSelectSubRows
toggleSelected
getToggleSelectedHandler
行选择状态 (Row Selection) 在表格中使用以下结构存储:
export type RowSelectionState = Record<string, boolean>
export type RowSelectionTableState = {
rowSelection: RowSelectionState
}
export type RowSelectionState = Record<string, boolean>
export type RowSelectionTableState = {
rowSelection: RowSelectionState
}
默认情况下,行选择状态使用每行的索引作为行标识符。也可以通过向表格传入自定义的 getRowId 函数,使用自定义的唯一行 ID 来跟踪行选择状态。
enableRowSelection?: boolean | ((row: Row<TData>) => boolean)
enableRowSelection?: boolean | ((row: Row<TData>) => boolean)
enableMultiRowSelection?: boolean | ((row: Row<TData>) => boolean)
enableMultiRowSelection?: boolean | ((row: Row<TData>) => boolean)
enableSubRowSelection?: boolean | ((row: Row<TData>) => boolean)
enableSubRowSelection?: boolean | ((row: Row<TData>) => boolean)
启用/禁用当父行被选中时自动选择子行的功能,或一个为每行启用/禁用自动子行选择功能的函数。
(需与展开或分组功能结合使用)
onRowSelectionChange?: OnChangeFn<RowSelectionState>
onRowSelectionChange?: OnChangeFn<RowSelectionState>
如果提供,当 state.rowSelection 发生变化时,此函数将被调用并传入一个 updaterFn。这会覆盖默认的内部状态管理,因此您需要在表格外部完全或部分地持久化状态变更。
getToggleAllRowsSelectedHandler: () => (event: unknown) => void
getToggleAllRowsSelectedHandler: () => (event: unknown) => void
返回一个可用于切换表格中所有行选择状态的处理器。
getToggleAllPageRowsSelectedHandler: () => (event: unknown) => void
getToggleAllPageRowsSelectedHandler: () => (event: unknown) => void
返回一个可用于切换当前页所有行选择状态的处理器。
setRowSelection: (updater: Updater<RowSelectionState>) => void
setRowSelection: (updater: Updater<RowSelectionState>) => void
设置或更新 state.rowSelection 状态。
resetRowSelection: (defaultState?: boolean) => void
resetRowSelection: (defaultState?: boolean) => void
将 rowSelection 状态重置为 initialState.rowSelection,或传入 true 强制重置为默认空状态 {}。
getIsAllRowsSelected: () => boolean
getIsAllRowsSelected: () => boolean
返回表格中所有行是否均被选中。
getIsAllPageRowsSelected: () => boolean
getIsAllPageRowsSelected: () => boolean
返回当前页所有行是否均被选中。
getIsSomeRowsSelected: () => boolean
getIsSomeRowsSelected: () => boolean
返回表格中是否有任意行被选中。
注意:如果所有行均被选中则返回 false。
getIsSomePageRowsSelected: () => boolean
getIsSomePageRowsSelected: () => boolean
返回当前页是否有任意行被选中。
toggleAllRowsSelected: (value: boolean) => void
toggleAllRowsSelected: (value: boolean) => void
选中/取消选中表格中所有行。
toggleAllPageRowsSelected: (value: boolean) => void
toggleAllPageRowsSelected: (value: boolean) => void
选中/取消选中当前页所有行。
getPreSelectedRowModel: () => RowModel<TData>
getPreSelectedRowModel: () => RowModel<TData>
getSelectedRowModel: () => RowModel<TData>
getSelectedRowModel: () => RowModel<TData>
getFilteredSelectedRowModel: () => RowModel<TData>
getFilteredSelectedRowModel: () => RowModel<TData>
getGroupedSelectedRowModel: () => RowModel<TData>
getGroupedSelectedRowModel: () => RowModel<TData>
getIsSelected: () => boolean
getIsSelected: () => boolean
返回该行是否被选中。
getIsSomeSelected: () => boolean
getIsSomeSelected: () => boolean
返回该行的部分子行是否被选中。
getIsAllSubRowsSelected: () => boolean
getIsAllSubRowsSelected: () => boolean
返回该行的所有子行是否均被选中。
getCanSelect: () => boolean
getCanSelect: () => boolean
返回该行是否可被选中。
getCanMultiSelect: () => boolean
getCanMultiSelect: () => boolean
返回该行是否支持多选。
getCanSelectSubRows: () => boolean
getCanSelectSubRows: () => boolean
返回当父行被选中时是否自动选择子行。
toggleSelected: (value?: boolean) => void
toggleSelected: (value?: boolean) => void
选中/取消选中该行。
getToggleSelectedHandler: () => (event: unknown) => void
getToggleSelectedHandler: () => (event: unknown) => void
返回一个可用于切换该行选择状态的处理器。
Your weekly dose of JavaScript news. Delivered every Monday to over 100,000 devs, for free.