vue 中通过监测滚动条加载数据(懒加载数据)
vue 中监测滚动条加载数据(懒加载数据)methods: {titleAlert(title) {console.log(title);alert(title)},// 获取滚动条当前的位置getScrollTop() {let scrollTop = 0if (document.d...
·
vue 中监测滚动条加载数据(懒加载数据)
methods: {
titleAlert(title) {
console.log(title);
alert(title)
},
// 获取滚动条当前的位置
getScrollTop() {
let scrollTop = 0
if (document.documentElement && document.documentElement.scrollTop) {
scrollTop = document.documentElement.scrollTop
} else if (document.body) {
scrollTop = document.body.scrollTop
}
return scrollTop
},
// 获取当前可视范围的高度
getClientHeight() {
let clientHeight = 0
if (document.body.clientHeight && document.documentElement.clientHeight) {
clientHeight = Math.min(document.body.clientHeight, document.documentElement.clientHeight)
} else {
clientHeight = Math.max(document.body.clientHeight, document.documentElement.clientHeight)
}
return clientHeight
},
// 获取文档完整的高度
getScrollHeight() {
return Math.max(document.body.scrollHeight, document.documentElement.scrollHeight)
},
// 滚动事件触发下拉加载
onScroll() {
if (this.getScrollHeight() - this.getClientHeight() - this.getScrollTop() <= 0) {
if (this.status <= 5) {
this.status++;
// 调用请求函数
this.axios.get('/rock/book/recommend?start=128&count=16&user_type=3&top_count=0&filter_count=6'
).then(data => {
this.data = this.data.concat(data.data.items)
// console.log(data.data.items);
console.log(this.data)
});
} else {
alert('没有更多内容了!!!');
}
}
},
},
mounted钩子函数监听滚动事件
mounted() {
this.$nextTick(function () {
window.addEventListener('scroll', this.onScroll);
console.log(this.data)
})
},
更多推荐
已为社区贡献4条内容
所有评论(0)