Blame view

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