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 el-calendar日历组件使用方法总结
这篇文章主要给大家介绍了关于element ui el-calendar日历组件使用方法的相关资料,elementui是一款基于Vue.js的UI框架,其中的日历组件calendar是elementui中非常常用的组件之一,需要的朋友可以参考下2023-07-07
Vue.js 带下拉选项的输入框(Textbox with Dropdown)组件
这篇文章主要介绍了Vue.js 带下拉选项的输入框(Textbox with Dropdown)组件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2021-04-04


最新评论