优化显隐列
This commit is contained in:
parent
29bdcf8ff3
commit
e776a95edb
@ -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;
|
||||||
}
|
}
|
||||||
</style>
|
.el-dropdown-menu {
|
||||||
|
max-height: 400px;
|
||||||
|
overflow-y: scroll;
|
||||||
|
overflow-x: hidden;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user