You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ant-design-vue/components/vc-table/demo/key.js

48 lines
1.1 KiB

/* eslint-disable no-console,func-names,react/no-multi-comp */
import Table from '../index'
import '../assets/index.less'
export default {
data () {
return {
data: [{ a: '123' }, { a: 'cdd', b: 'edd' }, { a: '1333', c: 'eee', d: 2 }],
}
},
methods: {
remove (index) {
const rows = this.data
rows.splice(index, 1)
this.data = rows
},
handleClick (index) {
this.remove(index)
},
checkbox (h, a) {
return <label>
<input type='checkbox' />
{a}
</label>
},
renderAction (h, o, row, index) {
return <a href='javascript:;' onClick={() => this.handleClick(index)}>Delete</a>
},
},
render () {
const columns = [
{ title: 'title1', dataIndex: 'a', key: 'a', width: 100, render: this.checkbox },
{ title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
{ title: 'Operations', dataIndex: '', key: 'x', render: this.renderAction },
]
return (
<Table columns={columns} data={this.data} class='table' rowKey={record => record.a} />
)
},
}