2019-12-10 19:16:25 +08:00
|
|
|
# Selection
|
2019-12-10 18:49:06 +08:00
|
|
|
|
2020-02-04 22:43:40 +08:00
|
|
|
Rows can be selectable by making first column's type as `selection`.
|
2019-12-10 18:49:06 +08:00
|
|
|
|
|
|
|
```html
|
2020-01-31 17:02:33 +08:00
|
|
|
<div>You have selected {{ checkedRowKeys.length }} row{{ checkedRowKeys.length < 2 ? '': 's'}}.</div>
|
2020-01-05 15:20:35 +08:00
|
|
|
|
2019-12-31 21:01:24 +08:00
|
|
|
<n-data-table
|
2019-12-10 18:49:06 +08:00
|
|
|
ref="table"
|
|
|
|
:columns="columns"
|
|
|
|
:data="data"
|
|
|
|
:pagination="pagination"
|
2020-03-09 16:31:27 +08:00
|
|
|
:row-key="row => row.address"
|
2020-01-31 17:02:33 +08:00
|
|
|
@checked-row-keys-change="handleCheck"
|
|
|
|
/>
|
2019-12-10 18:49:06 +08:00
|
|
|
```
|
|
|
|
|
|
|
|
```js
|
2020-01-05 15:20:35 +08:00
|
|
|
const columns = [
|
|
|
|
{
|
2020-01-10 14:43:10 +08:00
|
|
|
type: 'selection',
|
|
|
|
disabled (row, index) {
|
|
|
|
return row.name === 'Edward King 3'
|
2019-12-10 18:49:06 +08:00
|
|
|
}
|
2020-01-05 15:20:35 +08:00
|
|
|
},
|
|
|
|
{
|
2020-01-10 14:43:10 +08:00
|
|
|
title: 'Name',
|
|
|
|
key: 'name'
|
2020-01-05 15:20:35 +08:00
|
|
|
},
|
|
|
|
{
|
2020-01-10 14:43:10 +08:00
|
|
|
title: 'Age',
|
|
|
|
key: 'age'
|
2020-01-05 15:20:35 +08:00
|
|
|
},
|
|
|
|
{
|
2020-01-10 14:43:10 +08:00
|
|
|
title: 'Address',
|
|
|
|
key: 'address'
|
2020-01-05 15:20:35 +08:00
|
|
|
}
|
|
|
|
]
|
2019-12-10 18:49:06 +08:00
|
|
|
|
2020-01-10 14:43:10 +08:00
|
|
|
const data = Array.apply(null, { length: 46 }).map((_, index) => ({
|
|
|
|
name: `Edward King ${index}`,
|
|
|
|
age: 32,
|
|
|
|
address: `London, Park Lane no. ${index}`
|
|
|
|
}))
|
2020-01-05 22:46:13 +08:00
|
|
|
|
2019-12-10 18:49:06 +08:00
|
|
|
export default {
|
|
|
|
data() {
|
|
|
|
return {
|
2020-01-05 15:20:35 +08:00
|
|
|
data,
|
|
|
|
columns,
|
2020-01-31 17:02:33 +08:00
|
|
|
checkedRowKeys: [],
|
2020-01-10 14:43:10 +08:00
|
|
|
pagination: {
|
|
|
|
pageSize: 5
|
|
|
|
}
|
2019-12-10 18:49:06 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
sendMail(rowData) {
|
2020-01-10 14:43:10 +08:00
|
|
|
this.$NMessage.info('send mail to ' + rowData.name)
|
2019-12-10 18:49:06 +08:00
|
|
|
},
|
2020-01-31 17:02:33 +08:00
|
|
|
handleCheck (rowKeys) {
|
|
|
|
this.checkedRowKeys = rowKeys
|
2019-12-10 18:49:06 +08:00
|
|
|
}
|
|
|
|
}
|
2020-01-05 22:46:13 +08:00
|
|
|
}
|
2019-12-10 18:49:06 +08:00
|
|
|
```
|