2020-02-04 22:43:40 +08:00
|
|
|
# 基础用法
|
|
|
|
|
|
|
|
```html
|
|
|
|
<n-data-table
|
|
|
|
:columns="columns"
|
|
|
|
:data="data"
|
|
|
|
:pagination="pagination"
|
|
|
|
/>
|
|
|
|
```
|
|
|
|
|
|
|
|
```js
|
|
|
|
const createColumns = instance => {
|
|
|
|
return [
|
|
|
|
{
|
|
|
|
title: 'Name',
|
2020-02-14 16:50:06 +08:00
|
|
|
key: 'name',
|
|
|
|
width: '15%'
|
2020-02-04 22:43:40 +08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Age',
|
2020-02-14 16:50:06 +08:00
|
|
|
key: 'age',
|
|
|
|
width: '10%'
|
2020-02-04 22:43:40 +08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Address',
|
2020-02-14 16:50:06 +08:00
|
|
|
key: 'address',
|
|
|
|
width: '20%'
|
2020-02-04 22:43:40 +08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Tags',
|
|
|
|
key: 'tags',
|
2020-02-14 16:50:06 +08:00
|
|
|
width: '20%',
|
2020-02-04 22:43:40 +08:00
|
|
|
render (h, row) {
|
|
|
|
const tags = row.tags.map(tagKey => {
|
|
|
|
return (
|
|
|
|
h('n-tag', {
|
|
|
|
staticStyle: {
|
|
|
|
marginRight: '6px'
|
|
|
|
},
|
|
|
|
props: {
|
|
|
|
type: 'info'
|
|
|
|
}
|
|
|
|
}, [ tagKey ])
|
|
|
|
)
|
|
|
|
})
|
|
|
|
return tags
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Action',
|
|
|
|
key: 'actions',
|
2020-02-14 16:50:06 +08:00
|
|
|
width: '20%',
|
2020-02-04 22:43:40 +08:00
|
|
|
render (h, row) {
|
|
|
|
return h('n-button', {
|
|
|
|
props: {
|
|
|
|
size: 'small'
|
|
|
|
},
|
|
|
|
on: {
|
|
|
|
click: () => instance.sendMail(row)
|
|
|
|
}
|
|
|
|
}, [ 'Send Email' ])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
const data = [
|
|
|
|
{
|
|
|
|
key: 0,
|
|
|
|
name: 'John Brown',
|
|
|
|
age: 32,
|
|
|
|
address: 'New York No. 1 Lake Park',
|
|
|
|
tags: ['nice', 'developer']
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 1,
|
|
|
|
name: 'Jim Green',
|
|
|
|
age: 42,
|
|
|
|
address: 'London No. 1 Lake Park',
|
|
|
|
tags: ['loser']
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 2,
|
|
|
|
name: 'Joe Black',
|
|
|
|
age: 32,
|
|
|
|
address: 'Sidney No. 1 Lake Park',
|
|
|
|
tags: ['cool', 'teacher']
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
export default {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
data: data,
|
|
|
|
columns: createColumns(this)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
pagination() {
|
|
|
|
return { total: this.data.length, pageSize: 10 }
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
sendMail(rowData) {
|
|
|
|
this.$NMessage.info('send mail to ' + rowData.name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|