mirror of
https://github.com/tusen-ai/naive-ui.git
synced 2025-01-12 12:25:16 +08:00
1.9 KiB
1.9 KiB
Size
<n-data-table
size="small"
:columns="columns"
:data="data"
:pagination="pagination"
/>
<n-data-table
size="large"
:columns="columns"
:data="data"
:pagination="pagination"
/>
import { h, resolveComponent } from 'vue'
const createColumns = instance => {
return [
{
title: 'Name',
key: 'name',
width: '15%'
},
{
title: 'Age',
key: 'age',
width: '10%'
},
{
title: 'Address',
key: 'address',
width: '20%'
},
{
title: 'Tags',
key: 'tags',
width: '20%',
render (row) {
const tags = row.tags.map(tagKey => {
return (
h(resolveComponent('n-tag'), {
style: {
marginRight: '6px'
},
type: 'info'
}, { default: () => tagKey })
)
})
return tags
}
},
{
title: 'Action',
key: 'actions',
width: '20%',
render (row) {
return h(resolveComponent('n-button'), {
size: 'small',
onClick: () => instance.sendMail(row)
}, { default: () => '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 {
inject: ['message'],
data() {
return {
data: data,
columns: createColumns(this)
}
},
computed: {
pagination() {
return { total: this.data.length, pageSize: 10 }
}
},
methods: {
sendMail(rowData) {
this.message.info('send mail to ' + rowData.name)
}
}
}
.n-data-table {
margin-bottom: 12px;
}