1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- <template>
- <div class="parent" @click="layoutClick">
- <Headers class="headers"></Headers>
- <div style="margin-top: 50px;">
- <router-view></router-view>
- </div>
- <Footers class="mt-10"></Footers>
- <Slider v-if="whiteList.indexOf(router.currentRoute.value.path) === -1" class="slider"></Slider>
- </div>
- </template>
- <script setup>
- import Headers from './personal/navBar.vue'
- import Footers from './personal/footer.vue'
- import Slider from './personal/slider.vue'
- import { useSharedState } from '@/store/sharedState'
- import { useRouter } from 'vue-router'
- defineOptions({ name: 'layout-index' })
- // 不展示侧边栏名单
- const whiteList = ['/login', '/privacyPolicy', '/userAgreement', '/register']
- const router = useRouter()
- const sharedState = useSharedState()
- const layoutClick = () => {
- sharedState.increment()
- }
- </script>
- <style lang="scss" scoped>
- .parent {
- background-color: var(--default-bgc);
- position: relative;
- }
- .headers {
- position: fixed;
- right: 0;
- left: 0;
- top: 0;
- z-index: 999;
- }
- .slider {
- position: fixed;
- bottom: 50%;
- right: 24px;
- translate: 0 50%;
- z-index: 999;
- }
- </style>
|