| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
 | | <template> |  |     <div :class="classes" :style="styles" @click="back"> |  |         <slot> |  |             <div :class="innerClasses"> |  |                 <i class="ivu-icon ivu-icon-ios-arrow-up"></i> |  |             </div> |  |         </slot> |  |     </div> |  | </template> |  | <script> |  |     import { scrollTop } from '../../utils/assist'; |  |     import { on, off } from '../../utils/dom'; |  |     const prefixCls = 'ivu-back-top'; |  |   |  |     export default { |  |         props: { |  |             height: { |  |                 type: Number, |  |                 default: 400 |  |             }, |  |             bottom: { |  |                 type: Number, |  |                 default: 30 |  |             }, |  |             right: { |  |                 type: Number, |  |                 default: 30 |  |             }, |  |             duration: { |  |                 type: Number, |  |                 default: 1000 |  |             } |  |         }, |  |         data () { |  |             return { |  |                 backTop: false |  |             }; |  |         }, |  |         mounted () { |  | //            window.addEventListener('scroll', this.handleScroll, false); |  | //            window.addEventListener('resize', this.handleScroll, false); |  |             on(window, 'scroll', this.handleScroll); |  |             on(window, 'resize', this.handleScroll); |  |         }, |  |         beforeDestroy () { |  | //            window.removeEventListener('scroll', this.handleScroll, false); |  | //            window.removeEventListener('resize', this.handleScroll, false); |  |             off(window, 'scroll', this.handleScroll); |  |             off(window, 'resize', this.handleScroll); |  |         }, |  |         computed: { |  |             classes () { |  |                 return [ |  |                     `${prefixCls}`, |  |                     { |  |                         [`${prefixCls}-show`]: this.backTop |  |                     } |  |                 ]; |  |             }, |  |             styles () { |  |                 return { |  |                     bottom: `${this.bottom}px`, |  |                     right: `${this.right}px` |  |                 }; |  |             }, |  |             innerClasses () { |  |                 return `${prefixCls}-inner`; |  |             } |  |         }, |  |         methods: { |  |             handleScroll () { |  |                 this.backTop = window.pageYOffset >= this.height; |  |             }, |  |             back () { |  |                 const sTop = document.documentElement.scrollTop || document.body.scrollTop; |  |                 scrollTop(window, sTop, 0, this.duration); |  |                 this.$emit('on-click'); |  |             } |  |         } |  |     }; |  | </script> | 
 |