<template> <div> <div class="app-container"> <el-button type="primary" size="small" style="margin:0 0 20px 0;"> <a href="https://github.com/PanJiaChen/vue-element-admin/tree/master/src/components/TreeTable" target="_blank">Documentation</a> </el-button> <tree-table ref="TreeTable" :data="tableData" :default-expand-all="true" :columns="columns" border default-children="children" @selection-change ="selectChange" > <template slot="selection"> <el-table-column type="selection" align="center" width="55"/> </template> <template slot="pre-column"> <el-table-column type="expand" width="55"> <template> <el-tag type="info"> Here is just a placeholder slot, you can display anything. </el-tag> </template> </el-table-column> </template> <template slot="timeline" slot-scope="{scope}"> <el-tooltip :content="scope.row.timeLine+'ms'" effect="dark" placement="left"> <div class="processContainer"> <div :style="{ width:(scope.row.timeLine||0) * 3+'px', background:scope.row.timeLine>50?'rgba(233,0,0,.5)':'rgba(0,0,233,0.5)', marginLeft:scope.row._level * 50+'px' }" class="process"> <span style="display:inline-block"/> </div> </div> </el-tooltip> </template> <template slot="append" slot-scope="{scope}"> <el-button size="mini" type="primary" @click="addMenuItem(scope.row,'brother')" >Append Brother </el-button> <el-button size="mini" type="primary" @click="addMenuItem(scope.row,'children')" >Append Child </el-button> </template> <template slot="operation" slot-scope="{scope}"> <el-button size="mini" type="success" @click="editItem(scope.row)">Edit</el-button> <el-button size="mini" type="danger" @click="deleteItem(scope.row)">Delete</el-button> </template> </tree-table> </div> <el-dialog :visible.sync="dialogFormVisible" title="Edit"> <el-form :model="tempItem" label-width="100px" style="width:600px"> <el-form-item label="Name"> <el-input v-model.trim="tempItem.name" placeholder="Name"/> </el-form-item> </el-form> <span slot="footer" class="dialog-footer"> <el-button @click="dialogFormVisible = false">Cancel</el-button> <el-button type="primary" @click="updateItem">Confirm</el-button> </span> </el-dialog> </div> </template> <script> import TreeTable from '@/components/TreeTable' import data from './data.js' export default { components: { TreeTable }, data() { return { tableData: [], tempItem: {}, dialogFormVisible: false, columns: [ { label: 'Name', key: 'name', expand: true }, { label: 'Timeline', key: 'timeline' }, { label: 'Append', key: 'append', width: 300 }, { label: 'Operation', key: 'operation', width: 160 } ] } }, created() { this.getData() }, methods: { getData() { this.tableData = data }, editItem(row) { this.tempItem = Object.assign({}, row) this.dialogFormVisible = true }, async updateItem() { await this.$refs.TreeTable.updateTreeNode(this.tempItem) this.dialogFormVisible = false }, addMenuItem(row, type) { if (type === 'children') { this.$refs.TreeTable.addChild(row, { name: 'child', timeLine: this.randomNum() }) } if (type === 'brother') { this.$refs.TreeTable.addBrother(row, { name: 'brother', timeLine: this.randomNum() }) } }, deleteItem(row) { this.$refs.TreeTable.delete(row) }, selectChange(val) { console.log(val) }, randomNum() { // return 1~100 const max = 100 const min = 1 return Math.floor(Math.random() * (max - min + 1) + min) } } } </script>