优化显隐列

This commit is contained in:
不做码农 2022-09-26 21:07:57 +08:00
parent 29bdcf8ff3
commit e776a95edb

View File

@ -1,5 +1,15 @@
<template> <template>
<div class="top-right-btn"> <div class="top-right-btn">
<el-dropdown :hide-on-click="false" style="margin-right: 10px" trigger="click">
<el-button circle icon="menu" />
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item v-for="(item, index) in data" :key="index">
<el-checkbox v-model="item.visible" :label="item.label"></el-checkbox>
</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
<el-tooltip class="item" effect="dark" :content="showSearch ? '隐藏搜索' : '显示搜索'" placement="top"> <el-tooltip class="item" effect="dark" :content="showSearch ? '隐藏搜索' : '显示搜索'" placement="top">
<el-button circle icon="Search" @click="toggleSearch()" /> <el-button circle icon="Search" @click="toggleSearch()" />
@ -7,77 +17,94 @@
<el-tooltip class="item" effect="dark" content="刷新" placement="top"> <el-tooltip class="item" effect="dark" content="刷新" placement="top">
<el-button circle icon="Refresh" @click="refresh()" /> <el-button circle icon="Refresh" @click="refresh()" />
</el-tooltip> </el-tooltip>
<el-tooltip class="item" effect="dark" content="显隐列" placement="top" v-if="columns"> <!-- <el-tooltip class="item" effect="dark" content="显隐列" placement="top" v-if="data">
<el-button circle icon="Menu" @click="showColumn()" /> <el-button circle icon="Menu" @click="showColumn()" />
</el-tooltip> </el-tooltip> -->
<el-dialog :title="title" v-model="open" append-to-body> <!-- <el-dialog :title="title" v-model="open" append-to-body>
<el-transfer :titles="['显示', '隐藏']" v-model="value" :data="columns" @change="dataChange"></el-transfer> <el-transfer :titles="['隐藏', '显示']" v-model="value" :data="data" @change="dataChange"></el-transfer>
</el-dialog> </el-dialog> -->
</div> </div>
</template> </template>
<script setup> <script setup>
import { ref } from 'vue'
const props = defineProps({ const props = defineProps({
showSearch: { showSearch: {
type: Boolean, type: Boolean,
default: true, default: true
}, },
columns: { columns: {
type: Array, type: Object
}, }
}); })
const emits = defineEmits(["update:showSearch", "queryTable"]); const data = computed(() => {
if (!props.columns) return undefined
return Object.values(props.columns).map((element, index) => {
element.key = index
return element
})
})
const emits = defineEmits(['update:showSearch', 'queryTable'])
// //
const value = ref([]); const value = ref([])
// //
const title = ref("显示/隐藏"); const title = ref('显示/隐藏')
// //
const open = ref(false); const open = ref(false)
// //
function toggleSearch() { function toggleSearch() {
emits("update:showSearch", !props.showSearch); emits('update:showSearch', !props.showSearch)
} }
// //
function refresh() { function refresh() {
emits("queryTable"); emits('queryTable')
} }
// //
function dataChange(data) { function dataChange(item) {
for (let item in props.columns) { let arrSelected = data.value.filter((element) => value.value.indexOf(element.key) > -1)
const key = props.columns[item].key;
props.columns[item].visible = !data.includes(key); arrSelected.forEach((element) => {
} element.visible = true
})
let arrUnSelected = data.value.filter((element) => value.value.indexOf(element.key) == -1)
arrUnSelected.forEach((element) => {
element.visible = false
})
} }
// dialog // dialog
function showColumn() { function showColumn() {
open.value = true; open.value = true
} }
const init = () => {
// if (props.columns) {
for (let item in props.columns) { Object.values(props.columns).forEach((element, index) => {
if (props.columns[item].visible === false) { if (element.visible == true) value.value.push(index)
value.value.push(parseInt(item)); })
} }
} }
console.log(data.value)
init()
</script> </script>
<style lang='scss' scoped> <style lang="scss" scoped>
.top-right-btn { .top-right-btn {
flex: 1; flex: 1;
text-align: right; text-align: right;
} }
:deep(.el-transfer__button) { :deep(.el-transfer__button) {
border-radius: 50%; border-radius: 50%;
display: block; display: block;
margin-left: 0px; margin-left: 0px;
} }
:deep(.el-transfer__button:first-child) { :deep(.el-transfer__button:first-child) {
margin-bottom: 10px; margin-bottom: 10px;
} }
@ -85,4 +112,9 @@ for (let item in props.columns) {
.my-el-transfer { .my-el-transfer {
text-align: center; text-align: center;
} }
.el-dropdown-menu {
max-height: 400px;
overflow-y: scroll;
overflow-x: hidden;
}
</style> </style>