iview/src/components/back-top/back-top.vue

77 lines
2.1 KiB
Vue
Raw Normal View History

2016-09-09 14:29:19 +08:00
<template>
<div :class="classes" :style="styles" @click="back">
<slot>
<div :class="innerClasses">
<i class="ivu-icon ivu-icon-chevron-up"></i>
</div>
</slot>
</div>
</template>
<script>
import { scrollTop } from '../../utils/assist';
2016-09-09 14:29:19 +08:00
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
2016-09-09 14:29:19 +08:00
}
},
data () {
return {
backTop: false
2016-12-25 22:49:42 +08:00
};
2016-09-09 14:29:19 +08:00
},
2017-03-07 10:03:11 +08:00
mounted () {
2016-09-09 14:29:19 +08:00
window.addEventListener('scroll', this.handleScroll, false);
window.addEventListener('resize', this.handleScroll, false);
},
beforeDestroy () {
window.removeEventListener('scroll', this.handleScroll, false);
window.removeEventListener('resize', this.handleScroll, false);
},
computed: {
classes () {
return [
`${prefixCls}`,
{
[`${prefixCls}-show`]: this.backTop
}
2016-12-25 22:49:42 +08:00
];
2016-09-09 14:29:19 +08:00
},
styles () {
return {
bottom: `${this.bottom}px`,
right: `${this.right}px`
2016-12-25 22:49:42 +08:00
};
2016-09-09 14:29:19 +08:00
},
innerClasses () {
return `${prefixCls}-inner`;
}
},
methods: {
handleScroll () {
2016-11-14 21:30:00 +08:00
this.backTop = window.pageYOffset >= this.height;
2016-09-09 14:29:19 +08:00
},
back () {
2017-05-26 09:45:05 +08:00
const sTop = document.documentElement.scrollTop || document.body.scrollTop;
2017-05-25 18:48:46 +08:00
scrollTop(window, sTop, 0, this.duration);
2016-09-09 14:29:19 +08:00
this.$emit('on-click');
}
}
2016-12-25 22:49:42 +08:00
};
2016-11-14 21:30:00 +08:00
</script>