---
title: "init(of:selection:sortOrder:columnCustomization:columns:rows:)"
framework: swiftui
role: symbol
role_heading: Initializer
path: "swiftui/table/init(of:selection:sortorder:columncustomization:columns:rows:)"
---

# init(of:selection:sortOrder:columnCustomization:columns:rows:)

Creates a sortable table with the given columns and rows that supports selecting multiple rows and dynamically customizable columns.

## Declaration

```swift
nonisolated init<Sort>(of valueType: Value.Type = Value.self, selection: Binding<Set<Value.ID>>, sortOrder: Binding<[Sort]>, columnCustomization: Binding<TableColumnCustomization<Value>>, @TableColumnBuilder<Value, Sort> columns: () -> Columns, @TableRowBuilder<Value> rows: () -> Rows) where Sort : SortComparator, Columns.TableRowValue == Sort.Compared
```

## Parameters

- `valueType`: The type of value used to derive the table’s contents.
- `selection`: A binding to a set that identifies selected rows ids.
- `sortOrder`: A binding to the ordered sorting of columns.
- `columnCustomization`: A binding to the state of columns.
- `columns`: The columns to display in the table.
- `rows`: The rows to display in the table.

## Discussion

Discussion Each column in the table that should participate in customization is required to have an identifier, specified with customizationID(_:).

## See Also

### Creating a table with dynamically customizable columns

- [init(of:columnCustomization:columns:rows:)](swiftui/table/init(of:columncustomization:columns:rows:).md)
- [init(of:selection:columnCustomization:columns:rows:)](swiftui/table/init(of:selection:columncustomization:columns:rows:).md)
- [init(of:sortOrder:columnCustomization:columns:rows:)](swiftui/table/init(of:sortorder:columncustomization:columns:rows:).md)
