mirror of
https://github.com/iczer/vue-antd-admin
synced 2025-04-06 04:00:06 +08:00
159 lines
3.9 KiB
Vue
159 lines
3.9 KiB
Vue
<template>
|
|
<form :autoFormCreate="(form) => this.form = form">
|
|
<a-table
|
|
:columns="columns"
|
|
:dataSource="dataSource"
|
|
:pagination="false"
|
|
>
|
|
<template v-for="(col, i) in ['name', 'workId', 'department']" :slot="col" slot-scope="text, record, index">
|
|
<a-input
|
|
:key="col"
|
|
v-if="record.editable"
|
|
style="margin: -5px 0"
|
|
:value="text"
|
|
:placeholder="columns[i].title"
|
|
@change="e => handleChange(e.target.value, record.key, col)"
|
|
/>
|
|
<template v-else>{{text}}</template>
|
|
</template>
|
|
<template slot="operation" slot-scope="text, record, index">
|
|
<template v-if="record.editable">
|
|
<span v-if="record.isNew">
|
|
<a @click="saveRow(record.key)">添加</a>
|
|
<a-divider type="vertical" />
|
|
<a-popconfirm title="是否要删除此行?" @confirm="remove(record.key)">
|
|
<a>删除</a>
|
|
</a-popconfirm>
|
|
</span>
|
|
<span v-else>
|
|
<a @click="saveRow(record.key)">保存</a>
|
|
<a-divider type="vertical" />
|
|
<a @click="cancle(record.key)">取消</a>
|
|
</span>
|
|
</template>
|
|
<span v-else>
|
|
<a @click="toggle(record.key)">编辑</a>
|
|
<a-divider type="vertical" />
|
|
<a-popconfirm title="是否要删除此行?" @confirm="remove(record.key)">
|
|
<a>删除</a>
|
|
</a-popconfirm>
|
|
</span>
|
|
</template>
|
|
</a-table>
|
|
<a-button style="width: 100%; margin-top: 16px; margin-bottom: 8px" type="dashed" icon="plus" @click="newMeber">新增成员</a-button>
|
|
</form>
|
|
</template>
|
|
|
|
<script>
|
|
const columns = [
|
|
{
|
|
title: '成员姓名',
|
|
dataIndex: 'name',
|
|
key: 'name',
|
|
width: '20%',
|
|
scopedSlots: { customRender: 'name' }
|
|
},
|
|
{
|
|
title: '工号',
|
|
dataIndex: 'workId',
|
|
key: 'workId',
|
|
width: '20%',
|
|
scopedSlots: { customRender: 'workId' }
|
|
},
|
|
{
|
|
title: '所属部门',
|
|
dataIndex: 'department',
|
|
key: 'department',
|
|
width: '40%',
|
|
scopedSlots: { customRender: 'department' }
|
|
},
|
|
{
|
|
title: '操作',
|
|
key: 'action',
|
|
scopedSlots: { customRender: 'operation' }
|
|
}
|
|
]
|
|
|
|
const dataSource = [
|
|
{
|
|
key: '1',
|
|
name: '小明',
|
|
workId: '001',
|
|
editable: false,
|
|
department: '行政部'
|
|
},
|
|
{
|
|
key: '2',
|
|
name: '李莉',
|
|
workId: '002',
|
|
editable: false,
|
|
department: 'IT部'
|
|
},
|
|
{
|
|
key: '3',
|
|
name: '王小帅',
|
|
workId: '003',
|
|
editable: false,
|
|
department: '财务部'
|
|
}
|
|
]
|
|
|
|
export default {
|
|
name: 'TableForm',
|
|
data () {
|
|
return {
|
|
columns,
|
|
dataSource
|
|
}
|
|
},
|
|
methods: {
|
|
handleSubmit (e) {
|
|
e.preventDefault()
|
|
},
|
|
newMeber () {
|
|
this.dataSource.push({
|
|
key: '99',
|
|
name: '',
|
|
workId: '',
|
|
department: '',
|
|
editable: true,
|
|
isNew: true
|
|
})
|
|
},
|
|
remove (key) {
|
|
const newData = this.dataSource.filter(item => item.key !== key)
|
|
this.dataSource = newData
|
|
},
|
|
saveRow (key) {
|
|
let target = this.dataSource.filter(item => item.key === key)[0]
|
|
target.editable = false
|
|
target.isNew = false
|
|
},
|
|
toggle (key) {
|
|
let target = this.dataSource.filter(item => item.key === key)[0]
|
|
target.editable = !target.editable
|
|
},
|
|
getRowByKey (key, newData) {
|
|
const data = this.dataSource
|
|
return (newData || data).filter(item => item.key === key)[0]
|
|
},
|
|
cancle (key) {
|
|
let target = this.dataSource.filter(item => item.key === key)[0]
|
|
target.editable = false
|
|
},
|
|
handleChange (value, key, column) {
|
|
const newData = [...this.dataSource]
|
|
const target = newData.filter(item => key === item.key)[0]
|
|
if (target) {
|
|
target[column] = value
|
|
this.dataSource = newData
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
|
|
</style>
|