vue实现滚动底部加载下一页指令的示例代码
更新时间:2023年10月09日 15:20:27 作者:旧城梦空
vue中监控滚动事件可以直接在mounted中绑定滚动事件,然后在销毁前解绑滚动事件,本文通过实例代码介绍vue实现滚动底部加载下一页指令的过程,感兴趣的朋友跟随小编一起看看吧
vue中监控滚动事件可以直接在mounted中绑定滚动事件,然后在销毁前解绑滚动事件,例如:
<script>
export default {
mounted() {
//我这里的事例监听的是window的滚动事件
window.addEventListener('scroll', this.showbtn)
},
destroyed() {
window.removeEventListener('scroll', this.showbtn)
},
methods:{
showbtn() {
//滚动事件的代码
}
}
}
</script>但是如果在项目中用的比较多的话,每个页面都这样写就有点不合适了。那这个时候可以把滚动事件自定义成指令
Vue.directive('scroll',{
bind(el,binding) {
let p = 0
let t = 0
let down = true
let timer = null
el.handler = () => {
p = window.pageYOffset ||
document.documentElement.scrollTop ||
document.body.scrollTop
if (t < p) {
down = true
} else {
down = false
}
t = p
let sign = 10
let scrollHeight=document.documentElement.scrollHeight//滚动条的高度
let clientHeight=document.documentElement.clientHeight//浏览器的可视高度
const scrollDistance = scrollHeight -p -clientHeight
if (scrollDistance < sign && down) {
if (timer) clearTimeout(timer)
timer = setTimeout(() => {
binding.value()
}, 300)
}
}
setTimeout(() => {
window.addEventListener('scroll',el.handler)
},1000)
},
//只有绑定不解绑的话,会出现在页面加载的时候调用之前请求过的接口的情况,所以加上解绑比较好
unbind(el) {
window.removeEventListener('scroll',el.handler)
}
})到此这篇关于vue实现滚动底部加载下一页指令的文章就介绍到这了,更多相关vue滚动底部加载内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
element-ui tree 异步树实现勾选自动展开、指定展开、指定勾选功能
这篇文章主要介绍了element-ui tree 异步树实现勾选自动展开、指定展开、指定勾选,项目中用到了vue的element-ui框架,用到了el-tree组件,由于数据量很大,使用了数据懒加载模式,即异步树,需要的朋友可以参考下2022-08-08
vue3中实现文本显示省略号和tooltips提示框的方式详解
在 B 端业务中,我们经常会遇到文本内容超出容器区域需显示省略号的需求,当鼠标移入文本时,会出现 Tooltip 显示完整内容,最近,我也遇到了这样的场景,接下来给大家介绍vue3中实现文本显示省略号和tooltips提示框的方式,需要的朋友可以参考下2024-04-04


最新评论