naive-ui/demo/documentation/components/dataTable/enUS/select.md

73 lines
1.2 KiB
Markdown

# Selection
Rows can be selectable by making first column as a selectable column.
```html
selected items: {{selectedData.length}}
<n-data-table
ref="table"
:columns="columns"
:data="data"
:pagination="pagination"
@on-selected-change="onSelectedChange"
>
</n-data-table>
```
```js
const _columns = $this => {
return [
{
type: "selection",
disabled(params, index) {
return params.row.name === "Edward King 3";
}
},
{
title: "Name",
key: "name"
},
{
title: "Age",
key: "age"
},
{
title: "Address",
key: "address"
}
];
};
const data = [];
for (let i = 0; i < 46; i++) {
data.push({
key: i,
name: `Edward King ${i}`,
age: 32,
address: `London, Park Lane no. ${i}`
});
}
export default {
data() {
return {
data: data,
columns: _columns(this),
selectedData: []
};
},
computed: {
pagination() {
return { total: this.data.length, limit: 5 };
}
},
methods: {
sendMail(rowData) {
this.$NMessage.info("send mail to " + rowData.name);
},
onSelectedChange(selectedData) {
this.selectedData = selectedData;
}
}
};
```