您的位置:首页 > Web前端 > Vue.js

vue+element-ui table实现滚动加载

2019-03-27 15:30 721 查看
版权声明:转载请注明出处,谢谢 https://blog.csdn.net/weixin_43953710/article/details/88846252

在main.js里注册

Vue.directive('loadmore', {
bind(el, binding) {
const selectWrap = el.querySelector('.el-table__body-wrapper')
selectWrap.addEventListener('scroll', function() {
let sign = 0
const scrollDistance = this.scrollHeight - this.scrollTop - this.clientHeight
if (scrollDistance <= sign) {
binding.value()
}
})
}
})

在组件中,使用自定义的事件:

v-loadmore=“loadMore”

在methods中调用loadMore

loadMore() {
console.log(this.loadSign)
if(this.aq == false){
return
}
if(this.page == 1){
this.page++
}

this.$axios({
method:'get',
url:this.api+'admin/StockLevel',
params:{
enabled:this.value1,
page:this.page,
limit:this.limit
}
}).then(res=>{
if(res.data.status==1){
if(res.data.result.list.length > 0){
this.page++
res.data.result.list.forEach(res => {
res.enabled = res.enabled.toString()
this.tableData.push(res)
});
console.log('到底了', this.page)
}else{
this.aq = false
}
}
})
},


这样就实现啦!!!

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: