feat: add slots support for StandardTable.vue; 🌟

新增:StandardTable.vue 组件增加 slots 支持;
This commit is contained in:
chenghongxing 2020-07-23 11:22:26 +08:00
parent 272f740597
commit 6c33fb0072
2 changed files with 39 additions and 6 deletions

View File

@ -20,11 +20,15 @@
:dataSource="dataSource" :dataSource="dataSource"
:rowKey="rowKey" :rowKey="rowKey"
:pagination="pagination" :pagination="pagination"
@change="onChange"
:rowSelection="{selectedRowKeys: selectedRowKeys, onChange: updateSelect}" :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: updateSelect}"
> >
<template slot-scope="text, record, index" :slot="slot" v-for="slot in scopedSlots"> <template slot-scope="text, record, index" :slot="slot" v-for="slot in scopedSlots">
<slot :name="slot" v-bind="{text, record, index}"></slot> <slot :name="slot" v-bind="{text, record, index}"></slot>
</template> </template>
<template :slot="slot" v-for="slot in slots">
<slot :name="slot"></slot>
</template>
</a-table> </a-table>
</div> </div>
</template> </template>
@ -36,13 +40,14 @@ export default {
data () { data () {
return { return {
needTotalList: [], needTotalList: [],
scopedSlots: [] scopedSlots: [],
slots: []
} }
}, },
methods: { methods: {
updateSelect (selectedRowKeys, selectedRows) { updateSelect (selectedRowKeys, selectedRows) {
this.$emit('update:selectedRows', selectedRows) this.$emit('update:selectedRows', selectedRows)
this.$emit('change', selectedRowKeys, selectedRows) this.$emit('selectedRowChange', selectedRowKeys, selectedRows)
}, },
initTotalList (columns) { initTotalList (columns) {
const totalList = [] const totalList = []
@ -54,16 +59,30 @@ export default {
return totalList return totalList
}, },
getScopedSlots(columns) { getScopedSlots(columns) {
return columns.filter(item => item.scopedSlots && item.scopedSlots.customRender) let scopedSlots = columns.filter(item => item.scopedSlots).map(item => item.scopedSlots)
.map(item => item.scopedSlots.customRender) scopedSlots = scopedSlots.flatMap(item => {
return Object.keys(item).map(key => item[key])
})
return scopedSlots
},
getSlots(columns) {
let slots = columns.filter(item => item.slots).map(item => item.slots)
slots = slots.flatMap(item => {
return Object.keys(item).map(key => item[key])
})
return slots
}, },
onClear() { onClear() {
this.updateSelect([], []) this.updateSelect([], [])
this.$emit('clear') this.$emit('clear')
},
onChange(pagination, filters, sorter, {currentDataSource}) {
this.$emit('change', pagination, filters, sorter, {currentDataSource})
} }
}, },
created () { created () {
this.scopedSlots = this.getScopedSlots(this.columns) this.scopedSlots = this.getScopedSlots(this.columns)
this.slots = this.getSlots(this.columns)
this.needTotalList = this.initTotalList(this.columns) this.needTotalList = this.initTotalList(this.columns)
}, },
watch: { watch: {

View File

@ -97,6 +97,8 @@
:dataSource="dataSource" :dataSource="dataSource"
:selectedRows.sync="selectedRows" :selectedRows.sync="selectedRows"
@clear="onClear" @clear="onClear"
@change="onChange"
@selectedRowChange="onSelectChange"
> >
<div slot="description" slot-scope="{text}"> <div slot="description" slot-scope="{text}">
{{text}} {{text}}
@ -104,6 +106,9 @@
<div slot="action" slot-scope="{text, record, index}"> <div slot="action" slot-scope="{text, record, index}">
<a-icon type="edit" />{{index}} <a-icon type="edit" />{{index}}
</div> </div>
<template slot="statusTitle">
<a-icon @click.native="onStatusTitleClick" type="info-circle" />
</template>
</standard-table> </standard-table>
</div> </div>
</a-card> </a-card>
@ -129,9 +134,9 @@ const columns = [
customRender: (text) => text + ' 次' customRender: (text) => text + ' 次'
}, },
{ {
title: '状态',
dataIndex: 'status', dataIndex: 'status',
needTotal: true needTotal: true,
slots: {title: 'statusTitle'}
}, },
{ {
title: '更新时间', title: '更新时间',
@ -179,6 +184,15 @@ export default {
onClear() { onClear() {
this.$message.info('您清空了勾选的所有行') this.$message.info('您清空了勾选的所有行')
}, },
onStatusTitleClick() {
this.$message.info('你点击了状态栏表头')
},
onChange() {
this.$message.info('表格状态改变了')
},
onSelectChange() {
this.$message.info('选中行改变了')
},
addNew () { addNew () {
this.dataSource.unshift({ this.dataSource.unshift({
key: this.dataSource.length, key: this.dataSource.length,