码迷,mamicode.com
首页 > 其他好文 > 详细

vue-滚动加载组件

时间:2020-05-12 13:54:53      阅读:76      评论:0      收藏:0      [点我收藏+]

标签:post   mon   ima   return   window   init   控制   tor   元素   

<template>
<div id="infiniteScroll" class="infinite-scroll">
    <slot></slot>
</div>
</template>

<script>
/** 
 * 用法:
 * 将该组件放在列表最下方,其直接父级元素为滚动的包含块
 * window.INFINITE_BUSY 用来控制是否监听无限加载
 * dis为开始进行下次加载的检测距离
*/
export default {
    data(){
        return {
            
        }
    },
    props:{
        dis:{
            type:Number,
            default:200
        }
    },
    mounted(){
        let detectDom = document.getElementById(‘infiniteScroll‘);
        let scrollDom = this.scrollDom = detectDom.parentElement;
        scrollDom.addEventListener(‘scroll‘,this.scrollMonitor);
        window.INFINITE_BUSY = false;
    },
    methods:{
        scrollMonitor(){
            if(window.INFINITE_BUSY) return;
            requestAnimationFrame(this.loadMonitor);
            window.INFINITE_BUSY = true;
        },
        loadMonitor(){
            let scrollDom = this.scrollDom;
            let totalLength = scrollDom.scrollHeight;
            let viewLength = scrollDom.clientHeight;
            let scrollLength = scrollDom.scrollTop;
            
            if(totalLength > viewLength && viewLength + scrollLength > totalLength - this.dis){
                this.$emit(‘loadmore‘)
                return
            }

            window.INFINITE_BUSY = false;
        }
    }
}
</script>

<style lang="postcss">

</style>

 

vue-滚动加载组件

标签:post   mon   ima   return   window   init   控制   tor   元素   

原文地址:https://www.cnblogs.com/sybboy/p/12875444.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!