成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

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

vuejs如何實現(xiàn)上滑加載,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學(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)站維護經(jīng)驗的網(wǎng)站建設(shè)公司。

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

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

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

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

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

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

原理:在Vue.js的鉤子函數(shù)created里初始化加載數(shù)據(jù),在鉤子函數(shù)mounted中聲明一個scroll事件監(jiān)聽,監(jiān)聽屏幕的高度變化,一旦滑動到達屏幕底部就去后臺請求新的數(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(){ //下面這部分兼容手機端和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中進行addEventListener監(jiān)聽,需加this.$nextTick(() => {}),他是將回調(diào)延遲到下次 DOM 更新循環(huán)之后執(zhí)行。
2.在vue里使用addEventListener('scroll',this.handleScroll,true),方法里的第三位必須加true,否則不生效。
3.vue中獲取元素焦點是在標簽中添加一個ref='定義名',然后在方法里

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

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

網(wǎng)頁題目:vuejs如何實現(xiàn)上滑加載
轉(zhuǎn)載來于:http://jinyejixie.com/article4/ijdgie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊、響應(yīng)式網(wǎng)站、面包屑導(dǎo)航、網(wǎng)站設(shè)計手機網(wǎng)站建設(shè)、定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管
鸡西市| 梁山县| 湘潭市| 霍山县| 安康市| 什邡市| 青神县| 都兰县| 万荣县| 哈密市| 伊宁市| 伊宁市| 内乡县| 北安市| 谢通门县| 白河县| 徐汇区| 司法| 五家渠市| 武功县| 浦城县| 久治县| 黄山市| 旬邑县| 洮南市| 新邵县| 子长县| 东城区| 巨鹿县| 穆棱市| 调兵山市| 易门县| 永川市| 旅游| 铁岭县| 神池县| 东乌| 柳江县| 利津县| 宁武县| 蒙山县|