ivew Table表格添加滚动条事件

Api.getStrongInfo(paramter).then((res) => {
    if(!this.searchInitFlag){
        console.log("初始化")
        this.tableData = res;
        setTimeout(()=>{
            this.bindScroll(res)
        }, 1000)
        this.loading = false //加载中样式
        this.searchInitFlag = true
    }

    if(this.selectPointFlag){
        console.log("加载")
        this.tableData = this.tableData.concat(res)
        this.loading = false 
    }   
})


//滚动条加载
bindScroll(res) {
    var _this = this
    const selectWrap = $('#scrollTable').find(".ivu-table-body.ivu-table-overflowY")[0]
    this.selectWrap = selectWrap
    const listenerFunction = function(el) {
        if (this.scrollHeight == this.scrollTop + this.clientHeight) {//判断滚动条是否滚动到底部
            _this.initTable(_this.selectPointFlag)
            _this.pageNum++
        }
    }
    selectWrap.addEventListener('scroll', listenerFunction)
}

判断滚动条到底部,需要用到DOM的三个属性值,即scrollTop、clientHeight、scrollHeight。

scrollTop为滚动条在Y轴上的滚动距离。

clientHeight为内容可视区域的高度。

scrollHeight为内容可视区域的高度加上溢出(滚动)的距离。

从这个三个属性的介绍就可以看出来,滚动条到底部的条件即为scrollTop + clientHeight == scrollHeight。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值