vue实现滑动超出指定距离回顶部功能
2019-07-31 16:17
1586 查看
本文实例为大家分享了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>
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- vue实现滑动超出指定距离回顶部功能
- vue+jquery+lodash实现滑动时顶部悬浮固定效果
- 使用Vue 实现滑动验证码功能
- Vue通过控制样式实现顶部导航点击切换、侧边栏点击切换、手风琴折叠面板等功能
- Android——UI篇:使用pinnedheaderlistview实现联系人头部滑动到顶部定住的功能
- Android实现bitmap指定区域滑动截取功能
- 实现页面指定div中滑块滑动距离
- vue+jquery+lodash 实现的滑动时顶部悬浮固定
- vue非父子组件通信(以实现全局“回到顶部”功能为例)
- cocos2d-x 基于CCClippingNode实现CCLayer遮罩功能,在滑动时超出剪切区域的实现显示部分的效果,不需要再借助其他sprite来遮挡了
- Android中实现 滑动时将指定View定位在顶部
- JS做”返回顶部”按钮功能并实现滑动效果
- vue中实现上下滑动文字通告的功能
- C++学习 【4.3】 利用函数实现指定的功能---内置函数
- Android 仿美团网,探索使用ViewPager+GridView实现左右滑动查看更多分类的功能
- JS获得指定元素距离浏览器顶部的距离offsetTop
- VUE 自定义表头实现table的过滤功能
- vue 实现通过手机发送短信验证码注册功能
- Vue实现一个无限加载列表功能
- Android程序开发之ListView 与PopupWindow实现从左向右滑动删除功能