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

vue 上滑加载更多

时间:2018-03-28 12:22:50      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:return   window   class   from   pos   ajax   this   let   false   

移动端网页的上滑加载更多,其实就是滑动+分页的实现。

 技术分享图片

 

<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(){
                $(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(self.page);
                    }
                });
            }
        }
    }
</script>

  精妙的地方在 getServerData()判断什么时候后端的数据全了,判断就是当前返回的数据长度小于约定的长度,说明到底了。

 

vue 上滑加载更多

标签:return   window   class   from   pos   ajax   this   let   false   

原文地址:https://www.cnblogs.com/xiaochongchong/p/8662669.html

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