|
@@ -1,5 +1,9 @@
|
1
|
1
|
<template>
|
2
|
|
- <div v-if="show" class="overlay" @click="onClose">
|
|
2
|
+ <div
|
|
3
|
+ v-if="show"
|
|
4
|
+ class="overlay"
|
|
5
|
+ @click="onClose"
|
|
6
|
+ >
|
3
|
7
|
<div class="warp" @click.stop>
|
4
|
8
|
<img :src="info.image" class="image" alt="" />
|
5
|
9
|
<div class="text" @scroll.passive="() => {}">
|
|
@@ -10,6 +14,8 @@
|
10
|
14
|
</template>
|
11
|
15
|
|
12
|
16
|
<script setup>
|
|
17
|
+import { onMounted, ref, watch } from 'vue';
|
|
18
|
+
|
13
|
19
|
const props = defineProps({
|
14
|
20
|
show: Boolean,
|
15
|
21
|
info: Object,
|
|
@@ -18,6 +24,17 @@ const props = defineProps({
|
18
|
24
|
default: () => {},
|
19
|
25
|
},
|
20
|
26
|
});
|
|
27
|
+
|
|
28
|
+const origin = document.body.style.overflow;
|
|
29
|
+
|
|
30
|
+watch(() => props.show, (val) => {
|
|
31
|
+ if (val) {
|
|
32
|
+ document.body.style.overflow = 'hidden';
|
|
33
|
+ } else {
|
|
34
|
+ document.body.style.overflow = origin;
|
|
35
|
+ }
|
|
36
|
+})
|
|
37
|
+
|
21
|
38
|
</script>
|
22
|
39
|
|
23
|
40
|
<style lang="less" scoped>
|