html:
<!-- flag 控制图片显示隐藏 -->
<!-- backTop 回顶部的方法 -->
<img v-if="flag" class="back" src="图片url" @click="backTop">
vue实例:
// vue的两个生命钩子.
// window对象,所有浏览器都支持window对象。它表示浏览器窗口,监听滚动事件
mounted () {
window.addEventListener('scroll', this.scrollToTop)
},
destroyed () {
window.removeEventListener('scroll', this.scrollToTop)
},
methods: {
// 点击图片回到顶部方法,加计时器是为了过渡顺滑
backTop () {
const that = this;
let timer = setInterval(() => {
let ispeed = Math.floor(-that.scrollTop / 5);
document.documentElement.scrollTop = document.body.scrollTop = that.scrollTop + ispeed;
if (that.scrollTop === 0) {
clearInterval(timer);
}
}, 16)
},
// 为了计算距离顶部的高度,当高度大于120显示回顶部图标,小于120则隐藏
scrollToTop () {
const that = this
let scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop;
that.scrollTop = scrollTop;
if (that.scrollTop > 120) {
that.flag = true;
} else {
that.flag = false;
}
}
}
原:https://blog.csdn.net/qq_36070288/article/details/84765139