溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

vuejs如何實(shí)現(xiàn)上滑加載

發(fā)布時間:2021-09-24 11:20:17 來源:億速云 閱讀:152 作者:柒染 欄目:編程語言

vuejs如何實(shí)現(xiàn)上滑加載,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

vuejs實(shí)現(xiàn)上滑加載的方法:1、在Vue.js的鉤子函數(shù)created里初始化加載數(shù)據(jù);2、聲明一個scroll事件監(jiān)聽;3、當(dāng)滑動到達(dá)屏幕底部就去后臺請求新的數(shù)據(jù);4、聲明一個pageNum字段;5、將新數(shù)據(jù)儲存到數(shù)組中。

本文操作環(huán)境:windows7系統(tǒng)、Vue2.9.6版、DELL G3電腦。

vuejs怎么實(shí)現(xiàn)上滑加載?

vue.js實(shí)現(xiàn)上拉加載

由于我的是純vue開發(fā)的,所以做了些優(yōu)化和修改,先看下效果

vuejs如何實(shí)現(xiàn)上滑加載

原理:在Vue.js的鉤子函數(shù)created里初始化加載數(shù)據(jù),在鉤子函數(shù)mounted中聲明一個scroll事件監(jiān)聽,監(jiān)聽屏幕的高度變化,一旦滑動到達(dá)屏幕底部就去后臺請求新的數(shù)據(jù),同時我們在data中聲明一個pageNum字段來記錄當(dāng)前加載到多少頁,pageSize每頁顯示個數(shù),pageNum當(dāng)前頁數(shù),每去后臺請求一次我們將pageSize加一定個數(shù),加載過后,將新的數(shù)據(jù)list到data中儲存數(shù)據(jù)的數(shù)組中。

代碼:

   created(){
            loading = showLoading('加載中…')//這是我引用的vant可以不寫
            this.custid = localStorage.getItem('cust_id')
            //初始化加載數(shù)據(jù)
            this.methodsGetMessage(this.custid,this.pageNum,this.pageSize)
        },
        mounted(){
            //監(jiān)聽如果頁面發(fā)生滾動時
            this.$nextTick(() => {
                this.$refs.homeUl.addEventListener('scroll',this.handleScroll,true);
            })
        },
        methods:{
            //初始化加載數(shù)據(jù)
            methodsGetMessage(custid,pageNum,pageSize){
                loading = showLoading('加載中…')
                getMessage(custid,pageNum,pageSize).then((res)=>{
                    loading.clear()
                    if(res.code == 200){
                        this.pagNum += 1;
                        if(res.data.list == []){
                            this.list = []
                            showToast('暫無消息')
                        }else{
                            this.totalnum = Math.ceil(res.data.total/8)
                            var list=res.data.list
                            for(var i in list){
                                list[i].addtime = this.dateToString(list[i].addtime)
                            }
                            this.list.push(list)
                            this.listLength = list.length
                        }
                        loading.clear()
                        //隱藏
                    }else{
                        showToast('獲取消息失敗')
                        loading.clear()
                    }
                })
            },
            //頁面滑到底部需要調(diào)用的方法
            handleScroll(){ //下面這部分兼容手機(jī)端和PC端
                var scrollTop = this.$refs.homeUl.scrollTop; //滾動條的位置
                var windowHeitht = this.$refs.homeUl.clientHeight; //在頁面上返回內(nèi)容的可視高度
                var scrollHeight = this.$refs.homeUl.scrollHeight; //返回整個元素的高度(包括帶滾動條的隱蔽的地方)
                //是否滾動到底部的判斷
                if(Math.round(scrollTop) + windowHeitht == scrollHeight){
                    console.log(this.pagNum+'=='+this.totalnum)
                    if(this.pagNum <= this.totalnum){
                        this.methodsGetMessage(this.custid,this.pageNum,this.pageSize)
                    }else{
                        this.notList = true
                        return;
                    }
                }
            },
  }

1.在鉤子函數(shù)mounted中進(jìn)行addEventListener監(jiān)聽,需加this.$nextTick(() => {}),他是將回調(diào)延遲到下次 DOM 更新循環(huán)之后執(zhí)行。
2.在vue里使用addEventListener('scroll',this.handleScroll,true),方法里的第三位必須加true,否則不生效。
3.vue中獲取元素焦點(diǎn)是在標(biāo)簽中添加一個ref='定義名',然后在方法里

this.$refs.定義名,來實(shí)現(xiàn)你想要的功能。
4.使用全屏的滾動條位置判斷會出錯,所以,我是消息列表是一個ul,獲取消息列表ul的滾動條可是高度,整個元素高度,來判斷的,判斷是否到達(dá)底部給滾動條的位置使用Math.round()向上取整,因?yàn)橛辛泓c(diǎn)幾的誤差,就醬。。

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI