<template> <div id="ZHPS"> <div :class="['LeftBox', 'animate__animated', showPanel ? 'animate__fadeOutLeft' : 'animate__fadeInLeft']">11111</div> <div :class="['RightBox', 'animate__animated', showPanel ? 'animate__fadeOutRight' : 'animate__fadeInRight']"></div> <div class="BottomBox">111</div> </div> <div v-if="showPanel == false" style="color: red; position: absolute; left: 500px; top: 500px" @click="goBack"> 放回放回返回 </div> <FHPL v-if="curType == true" /> </template> <script setup name="ZHPS"> import { ref, reactive, toRefs, onMounted, onBeforeUnmount } from 'vue'; import FHPL from '@/views/oneMap/components/FHPL.vue'; import bus from '@/bus'; const AllData = reactive({}); const curType = ref(false); const showPanel = ref(true); //面板展开收起 // 面板内容展开收起控制 const props = defineProps({ showPanel: { type: Boolean, }, }); function goBack(params) { console.log('111'); showPanel.value = true; curType.value = true; } watch( () => props.showPanel, () => { showPanel.value = props.showPanel; }, { immediate: true } ); onMounted(() => { bus.on('BottomHidden', params => { console.log(params, 'params111'); }); let initePSTimer = setInterval(() => { if (!newfiberMapbox) return; bus.emit('setLayerVisible', { layername: 'ysLine1', isCheck: true }); bus.emit('setLayerVisible', { layername: 'wsLine1', isCheck: true }); clearInterval(initePSTimer); }, 100); }); onBeforeUnmount(() => { bus.emit('setLayerVisible', { layername: 'ysLine1', isCheck: false }); bus.emit('setLayerVisible', { layername: 'wsLine1', isCheck: false }); }); </script> <style lang="scss" scoped> #ZHPS { .LeftBox { width: 450px; height: calc(100% - 98px); position: absolute; left: 10px; top: 70px; background: linear-gradient(0deg, rgba(0, 93, 114, 0.8) 0%, rgba(0, 93, 114, 0.8) 100%); border-radius: 6px; border: 1px solid #47eef3; box-shadow: inset 0 0 5px 5px #47eef38a; } .RightBox { width: 450px; height: calc(100% - 98px); position: absolute; right: 10px; top: 70px; background: linear-gradient(0deg, rgba(0, 93, 114, 0.8) 0%, rgba(0, 93, 114, 0.8) 100%); border-radius: 6px; border: 1px solid #47eef3; box-shadow: inset 0 0 5px 5px #47eef38a; } .BottomBox { width: 900px; height: 300px; position: absolute; right: 100px; top: 70px; background: linear-gradient(0deg, rgba(0, 93, 114, 0.8) 0%, rgba(0, 93, 114, 0.8) 100%); border-radius: 6px; border: 1px solid #47eef3; box-shadow: inset 0 0 5px 5px #47eef38a; } } </style>