2020-02-04 22:43:40 +08:00
|
|
|
# 选中行
|
|
|
|
可以通过把第一列的类型设为 `selection` 来让行变成可选的。
|
|
|
|
|
|
|
|
```html
|
|
|
|
<div>You have selected {{ checkedRowKeys.length }} row{{ checkedRowKeys.length < 2 ? '': 's'}}.</div>
|
|
|
|
|
|
|
|
<n-data-table
|
|
|
|
ref="table"
|
|
|
|
:columns="columns"
|
|
|
|
:data="data"
|
|
|
|
:pagination="pagination"
|
2020-03-09 12:08:29 +08:00
|
|
|
:row-key="row => row.address"
|
2020-02-04 22:43:40 +08:00
|
|
|
@checked-row-keys-change="handleCheck"
|
|
|
|
/>
|
|
|
|
```
|
|
|
|
|
|
|
|
```js
|
|
|
|
const columns = [
|
|
|
|
{
|
|
|
|
type: 'selection',
|
|
|
|
disabled (row, index) {
|
|
|
|
return row.name === 'Edward King 3'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Name',
|
|
|
|
key: 'name'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Age',
|
|
|
|
key: 'age'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Address',
|
|
|
|
key: 'address'
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
const data = Array.apply(null, { length: 46 }).map((_, index) => ({
|
|
|
|
name: `Edward King ${index}`,
|
|
|
|
age: 32,
|
|
|
|
address: `London, Park Lane no. ${index}`
|
|
|
|
}))
|
|
|
|
|
|
|
|
export default {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
data,
|
|
|
|
columns,
|
|
|
|
checkedRowKeys: [],
|
|
|
|
pagination: {
|
|
|
|
pageSize: 5
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
sendMail(rowData) {
|
|
|
|
this.$NMessage.info('send mail to ' + rowData.name)
|
|
|
|
},
|
|
|
|
handleCheck (rowKeys) {
|
|
|
|
this.checkedRowKeys = rowKeys
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|