gaoshp
2024-06-11 e87012567c674cd69f7a8f87df7202eac60a8208
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<template>
    <el-container>
        <el-header>
            <div class="left-panel">
                <el-button type="primary" icon="el-icon-plus" @click="add"></el-button>
            </div>
        </el-header>
        <el-main class="nopadding">
            <scTable ref="table" :apiObj="apiObj" row-key="id" @selection-change="selectionChange" stripe>
                <el-table-column type="selection" width="50"></el-table-column>
                <el-table-column label="标识" prop="code" width="150"></el-table-column>
                <el-table-column label="表格名称" prop="name" width="250"></el-table-column>
 
                <el-table-column label="操作" fixed="right" align="right" width="120">
                    <template #default="scope">
                        <el-button-group>
                            <el-button text type="primary" size="small" @click="table_edit(scope.row, scope.$index)">编辑</el-button>
                            <el-popconfirm title="确定删除吗?" @confirm="table_del(scope.row, scope.$index)">
                                <template #reference>
                                    <el-button text type="primary" size="small">删除</el-button>
                                </template>
                            </el-popconfirm>
                        </el-button-group>
                    </template>
                </el-table-column>
            </scTable>
        </el-main>
    </el-container>
    
    <save-dialog v-if="dialog.save" ref="saveDialog" @success="handleSuccess" @closed="dialog.save=false"></save-dialog>
    
</template>
 
<script>
    import saveDialog from './save'
    
    export default {
        name: 'tableSetting',
        components: {
            saveDialog
        },
        data() {
            return {
                dialog: {
                    save: false
                },
                apiObj: this.$API.system.table.list,
                selection: []
            }
        },
        mounted() {
 
        },
        methods: {
            //增加
            add(){
                this.dialog.save = true
                this.$nextTick(() => {
                    this.$refs.saveDialog.open()
                })
            },
            //编辑
            table_edit(row){
                this.dialog.save = true
                this.$nextTick(() => {
                    this.$refs.saveDialog.open('edit').setData(row)
                })
            },
            //删除
            async table_del(row, index){
                var reqData = {id: row.id}
                var res = await this.$API.demo.post.post(reqData);
                if(res.code == 200){
                    //这里选择刷新整个表格 OR 插入/编辑现有表格数据
                    this.$refs.table.tableData.splice(index, 1);
                    this.$message.success("删除成功")
                }else{
                    this.$alert(res.message, "提示", {type: 'error'})
                }
            },
            //批量删除
            async batch_del(){
                this.$confirm(`确定删除选中的 ${this.selection.length} 项吗?`, '提示', {
                    type: 'warning'
                }).then(() => {
                    const loading = this.$loading();
                    this.selection.forEach(item => {
                        this.$refs.table.tableData.forEach((itemI, indexI) => {
                            if (item.id === itemI.id) {
                                this.$refs.table.tableData.splice(indexI, 1)
                            }
                        })
                    })
                    loading.close();
                    this.$message.success("操作成功")
                }).catch(() => {
 
                })
            },
            //表格选择后回调事件
            selectionChange(selection){
                this.selection = selection;
            },
            //本地更新数据
            handleSuccess(data, mode){
                if(mode=='add'){
                    data.id = new Date().getTime()
                    this.$refs.table.tableData.unshift(data)
                }else if(mode=='edit'){
                    this.$refs.table.tableData.filter(item => item.id===data.id ).forEach(item => {
                        Object.assign(item, data)
                    })
                }
            }
        }
    }
</script>
 
<style>
</style>