vue 上滑加載更多

移動端網頁的上滑加載更多,其實就是滑動+分頁的實現。javascript

 

 

<template>
    <div>
        <p class="footer-text">--{{footerText}}--</p>
        <p class="loading" v-show="loading"></p>
    </div>
</template>
<script>
    import $ from 'jquery'
    export default {
        data(){
            return{
                serverData:[],//接受服務器的數據,
                page:1,
                footerText:'上滑加載更多',
                loading:false//loading的開關
            }
        },
        created(){
            this.getServerData(this.page);
            this.listenScroll();
        },
        beforeDestroy(){
            $(window).unbind('scroll');
        },
        methods:{
            getServerData(){
                //參數只有page,項目須要能夠添加
                //項目中的ajax方式可能跟這個不同,不要緊,思路是相同的。
                const num = 3;//每一頁接受多少條數據
                this.$api.get('url',{page:this.page},res=>{
                    this.loading = false;
                    this.serverData = res.data;//接受數據
                    if(res.data.length<num){
                        this.footerText = "到底了";
                        $(window).unbind('scroll');
                    }
                })
            },
            listenScroll(){
          let self = this;
                $(window).scroll(function () {
                    let scrollTop = $(window).scrollTop();
                    let windowTop = $(window).height();
                    let documentTop = $(document).height();
                    if(documentTop - windowTop <= scrollTop){
                        self.page++;
                        self.loading = true;
                        self.getServerData();
                    }
                });
            }
        }
    }
</script>

  

  精妙的地方在 getServerData()判斷何時後端的數據全了,判斷就是當前返回的數據長度小於約定的長度,說明到底了。php

 若是後端是thinkPhp,因爲有page()函數,那麼代碼相似這樣:java

  

//獲取page參數
$page = I('get.page',1);
//先後端約定每次顯示的條數
$num = 3;
$M
->where()
-> page($page,$num)
->select
相關文章
相關標籤/搜索