真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

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

創(chuàng)新互聯(lián)建站10多年成都企業(yè)網(wǎng)站定制服務(wù);為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計及高端網(wǎng)站定制服務(wù),成都企業(yè)網(wǎng)站定制及推廣,對成都戶外休閑椅等多個方面擁有多年的網(wǎng)站維護(hù)經(jīng)驗(yàn)的網(wǎng)站建設(shè)公司。

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)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。


當(dāng)前標(biāo)題:vuejs如何實(shí)現(xiàn)上滑加載
鏈接分享:http://weahome.cn/article/ijdgie.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部