时间:2021-05-26
本文实例为大家分享了vue实现滑动超出指定距离回顶部功能,供大家参考,具体内容如下
效果图展示:
1、当页面滑动时执行scrollToTop ()函数,判断滑动的距离是否超出指定距离,注意下面获取getElementsByClassName时,是你被滑动标签的class。
mounted() { window.addEventListener('scroll', this.scrollToTop, true) }scrollToTop () { let This = this let dom = document.getElementsByClassName('content')[0];//获取滑动模块的信息(注意class别写错) This.scrollTop = dom.scrollTop; if (This.scrollTop > 200) { This.btnFlag = true } else { This.btnFlag = false }}2、当超出指定距离会出来向上的小图标,点击执行backTop ()函数回顶部。图标我是用的阿里矢量图标引入到项目中,样式自己调一下。
// 点击图标回到顶部方法,加计时器是为了缓慢回到顶部backTop () { let This = this let timer = setInterval(() => { let ispeed = Math.floor(-This.scrollTop / 5) document.getElementsByClassName('content')[0].scrollTop = This.scrollTop + ispeed if (This.scrollTop === 0) { clearInterval(timer) } }, 16)},完整代码请看下面:
<template> <div class="scrollTop-wrap"> <div v-if="btnFlag" class="go-top"> <li class="iconfont iconhuidaodingbu" @click="backTop()"></li> </div> </div></template><script> import { httpGetMethod } from '../common/httpService' export default { name: 'scrollTop', data: function () { return { btnFlag:false, scrollTop:0//当前滑动距离 } }, mounted() { window.addEventListener('scroll', this.scrollToTop, true) }, destroyed () { window.removeEventListener('scroll', this.scrollToTop, true) }, methods: { // 点击图标回到顶部方法,加计时器是为了缓慢回到顶部 backTop () { let This = this let timer = setInterval(() => { let ispeed = Math.floor(-This.scrollTop / 5) document.getElementsByClassName('content')[0].scrollTop = This.scrollTop + ispeed if (This.scrollTop === 0) { clearInterval(timer) } }, 16) }, // 计算距离顶部的高度,当高度大于200显示回顶部图标,小于200则隐藏 scrollToTop () { let This = this let dom = document.getElementsByClassName('content')[0];//获取滑动模块的信息(注意class别写错) This.scrollTop = dom.scrollTop; if (This.scrollTop > 200) { This.btnFlag = true } else { This.btnFlag = false } } } }</script><style lang="scss"> @import '../styles/mixin'; .scrollTop-wrap { position: relative; .go-top{ position: absolute; top: 430px; left: 260px; z-index: 15; .iconhuidaodingbu{ font-size: 30px; color: #87878A; background-color:#fff; border-radius: 50%; } } }</style>在其他页面引用一下:
<template> <div class="wtll-wrap"> <div calss="content"> 这里是你的滑动内容 </div> <scrollTop></scrollTop> </div></template><script> import scrollTop from '../components/scrollTop' export default { name: 'wtll', data: function () { return { } }, components: { scrollTop }, methods: { } }</script>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
实例如下://滑动滚动条$(window).scroll(function(){//滚动条距离顶部的距离大于200px时if($(window).scrollT
其实实现起来并不难,我们先把实现流程大致想一下,首先,如果导航在显示范围内,就不用做修改。当导航超出显示范围,也就是导航距离屏幕顶部的距离小于0的时候,我们要让
实现功能如下:1.二维码展示功能;2.“回到顶部”功能。(选择“全屏预览”,滑动滚动条,查看回到顶部功能)效果图:图(1)初始效果图(2)鼠标悬浮效果实例代码:
本文实例讲述了js实现漂浮回顶部按钮的方法。分享给大家供大家参考。具体实现方法如下:漂浮回顶部按钮body{height:2000px;}.rTop{width
阻尼滑动效果,简单来说,就是页面顶部的菜单在页面开始向上/向下滑动的时候并不跟页面一起运动(如下图),直到页面滑动一定距离后才开始运动。这个效果在很多手机APP