tree.jsvue
import Vue from 'vue'
function DataTransfer (data) {
if (!(this instanceof DataTransfer)) {
return new DataTransfer(data, null, null)
}
}
DataTransfer.treeToArray = function (data, parent, level, expandedAll) {
let tmp = []
Array.from(data).forEach(function (record) {
if (record._expanded === undefined) {
Vue.set(record, '_expanded', expandedAll)
}
if (parent) {
Vue.set(record, '_parent', parent)
}
let _level = 0
if (level !== undefined && level !== null) {
_level = level + 1
}
Vue.set(record, '_level', _level)
tmp.push(record)
if (record.menuBeans && record.menuBeans.length > 0) {
let menuBeans = DataTransfer.treeToArray(record.menuBeans, record, _level, expandedAll)
tmp = tmp.concat(menuBeans)
}
})
return tmp
}
export default DataTransfer
index.jsapi
import MSDataTransfer from './tree.js'
export default {
MSDataTransfer
}
tableTree.vue微信
<template> <el-table :data="data" :row-style="showTr"> <el-table-column v-for="(column, index) of columns" :key="column.dataIndex" :label="column.text" align="center"> <template scope="scope"> <span v-if="spaceIconShow(index)" v-for="(space, levelIndex) of scope.row._level" class="ms-tree-space" :key="levelIndex"></span> <span v-if="toggleIconShow(index,scope.row)" @click="toggle(scope.$index)"> <i v-if="!scope.row._expanded" class="el-icon-caret-right" aria-hidden="true"></i> <i v-if="scope.row._expanded" class="el-icon-caret-bottom" aria-hidden="true"></i> </span> <span v-else-if="index===0" class="ms-tree-space"></span> {{scope.row[column.dataIndex] | btnType}} </template> </el-table-column> <el-table-column align="center" label="操做" v-if="treeType === 'normal'"> <template slot-scope="props"> <el-button type="primary" size="small" plain>修改</el-button> <el-button type="danger" size="small" plain>刪除</el-button> </template> </el-table-column> </el-table> </template> <script> import Utils from './tree' // import Vue from 'vue' export default { name: 'tree-grid', props: { // 該屬性是確認父組件傳過來的數據是否已是樹形結構了,若是是,則不須要進行樹形格式化 treeStructure: { type: Boolean, default: function () { return false } }, // 這是相應的字段展現 columns: { type: Array, default: function () { return [] } }, // 這是數據源 dataSource: { type: Array, default: function () { return [] } }, // 這個做用是根據本身需求來的,好比在操做中涉及相關按鈕編輯,刪除等,須要向服務端發送請求,則能夠把url傳過來 requestUrl: { type: String, default: function () { return '' } }, // 這個是是否展現操做列 treeType: { type: String, default: function () { return 'normal' } }, // 是否默認展開全部樹 defaultExpandAll: { type: Boolean, default: function () { return false } } }, data () { return {} }, computed: { // 格式化數據源 data: function () { let me = this if (me.treeStructure) { let data = Utils.MSDataTransfer.treeToArray(me.dataSource, null, null, me.defaultExpandAll) console.log('333',data) return data } return me.dataSource } }, filters: { btnType (value) { if(value === 'M') { return'菜單' } else if (value === 'B'){ return '按鈕' } else { return value } } }, methods: { // 顯示行 showTr(row, index) { let show = (row.row._parent ? (row.row._parent._expanded && row.row._parent._show) : true) row.row._show = show return show ? '' : 'display:none;' }, // 展開下級 toggle(trIndex) { let record = this.data[trIndex] record._expanded = !record._expanded }, // 顯示層級關係的空格和圖標 spaceIconShow(index) { if (this.treeStructure && index === 0) { return true } return false }, // 點擊展開和關閉的時候,圖標的切換 toggleIconShow (index, record) { if (this.treeStructure && index === 0 && record.menuBeans && record.menuBeans.length > 0) { return true } return false }, handleDelete () { this.$confirm('此操做將永久刪除該記錄, 是否繼續?', '提示', { confirmButtonText: '肯定', cancelButtonText: '取消', type: 'error' }).then(() => { this.$message({ type: 'success', message: '刪除成功!' }) }).catch(() => { this.$message({ type: 'info', message: '已取消刪除' }) }) } } } </script> <style scoped> .ms-tree-space{position: relative; top: 1px; display: inline-block; font-family: 'Glyphicons Halflings'; font-style: normal; font-weight: 400; line-height: 1; width: 18px; height: 14px;} .ms-tree-space::before{content: ""} table td{ line-height: 26px; } </style>
index.vueless
<template> <div> <el-form :inline="true" class="demo-form-inline"> <el-form-item> <el-button type="primary" @click="showDialog(0)">新增菜單</el-button> </el-form-item> </el-form> <!-- table start --> <table-tree :columns="columns" :tree-structure="true" :data-source="menuData"></table-tree> <!-- table end --> <!-- pagination start --> <el-pagination @current-change="initList" layout="total, prev, pager, next, jumper" :total="searchParamas.total" :page-size="searchParamas.pageSize"> </el-pagination> <!-- pagination end --> <!-- dialog start --> <el-dialog :title="title[titleStatus]" v-if="dialogStatus" :visible.sync="dialogStatus" center style="width:1000px;margin: 0 auto"> <add-form :btn-type="titleStatus" :menu="menuData" @refresh="refresh"></add-form> </el-dialog> <!-- dialog end --> </div> </template> <script> import addForm from './addForm' import tableTree from './tableTree' export default { data() { return { columns: [ { text: '菜單', dataIndex: 'menuName' }, { text: '類型', dataIndex: 'menuType' }, { text: '路徑', dataIndex: 'request' }, { text: '權限', dataIndex: 'permission' }, { text: '備註', dataIndex: 'remark' } ], menuData: [], searchParamas: { total: 0, pageNum: 1, pageSize: 10 }, dialogStatus: false, title: ['新增菜單', '修改菜單'], titleStatus: 0, id: '', defaultProps: { children: 'menuBeans', label: 'menuName' } } }, computed: { menuist(){ } }, methods: { initList(currentPage) { this.searchParamas.pageNum = currentPage || this.searchParamas.pageNum this.$apis.getMenuResult(this.searchParamas).then(res=> { if(res.code ===1) { this.menuData = res.menus this.searchParamas.total = res.total } }) }, showDialog(status, row) { this.dialogStatus = true this.titleStatus = status if(row) { console.log(row) this.id = row.id } }, deleteRow(row) { }, refresh() { this.initList() this.dialogStatus= false } }, components: { addForm, tableTree }, mounted() { this.initList() } } </script> <style lang="less" scoped> </style>
資料分享網站ide
能夠加我微信進羣,有資料送,也能夠討論問題網站