婚戀交友原始碼開發,移動端滾動載入更多元件的實現

雲豹科技程式設計師發表於2021-11-29

前言

之前在溝通婚戀交友原始碼移動端需求的時候,有個功能點就是關於滾動載入,滾動到底部以後,自動執行下次請求。這樣不僅優化了婚戀交友原始碼的效能,還提升了使用者的操作體驗,是很值得實現的一項功能。

實現

配置
在這裡插入圖片描述
原理

監聽婚戀交友原始碼中的滾動,當滾動到使用者配置的 bottom 時,執行下次請求,當請求完畢,不執行請求。當請求失敗時,提示元件請求失敗,婚戀交友原始碼中增加提示失敗資訊。

程式碼

<template>
  <div
    id="loadMore"
   
  >
    <slot></slot>
    <div
     
      id="loadTips"
      v-if="totalCount > 0 && totalCount >= pageSize"
    >
      <i
        v-show="loadTips=='正在載入中'"
       
      ></i>
      {{loadTips}}
    </div>
  </div>
</template>
<script>
let timer = null // 不作為響應式變數,提升效能
export default {
    props: {
        pageIndex: {
            type: Number,
            default: 1
        },
        pageSize: {
            type: Number,
            default: 10
        },
        totalCount: {
            type: Number,
            default: 0
        },
        delay: {
            type: [Number],
            default: 500
        },
        // 滾動條到達底部多少就會自動請求資料
        bottom: {
            type: [Number],
            default: 25
        },
        // 請求失敗預防針,測試中發現的這個
        fail: {
            type: Boolean,
            default: false
        },
        failTips: {
            type: String,
            default: '請求失敗,稍候重試!'
        }
    },
    data () {
        return {
            loadTips: '正在載入中'
        };
    },
    watch: {
        pageIndex () {
            this.loadMore()
        },
        totalCount: {
            handler (val, oldval) {
                if (val > 0) {
                    this.loadMore()
                }
            },
            // 首次請求
            immediate: true
        },
        fail (value) {
            if (value) {
                this.loadTips = this.failTips
            }
        }
    },
    methods: {
        // 上滑動載入更多
        loadMore () {
            this.loadTips = '正在載入中';
            const {pageSize, pageIndex, totalCount} = this
            return new Promise((resolve, reject) => {
                window.onscroll = () => {
                    timer = setTimeout(() => {
                        if (!document.getElementById('loadTips')) return
                        const clientHeight = document.documentElement.clientHeight || document.body.clientHeight || 0
                        const rectBottom = document.getElementById('loadTips').getBoundingClientRect().bottom || 0
                        if (rectBottom < clientHeight + this.bottom) {
                            const size = totalCount - pageIndex * pageSize
                            if (size > 0) {
                                this.$emit('loadmore', pageIndex + 1)
                                resolve(true)
                            } else {
                                this.loadTips = '沒有更多資料了'
                                resolve(false)
                            }
                            clearTimeout(timer)
                        }
                    }, this.delay)
                }
            })
        }
    },
    beforeDestroy () {
        clearTimeout(timer)
    }
};
</script>
<style scoped>
.loadmore-tip {
  color: #aaa;
  font-size: 12px;
  text-align: center;
  height: 40px;
  line-height: 40px;
}
@keyframes rotate-loading {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@-webkit-keyframes rotate-loading {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
.loadmore-icon {
  vertical-align: -2px;
  width: 12px;
  height: 12px;
  display: inline-block;
  background: url("")
    no-repeat;
  background-size: 12px 12px;
  -webkit-animation: rotate-loading 0.5s linear forwards infinite;
  animation: rotate-loading 0.5s linear forwards infinite;
}
</style>

以上就是“婚戀交友原始碼移動端實現滾動載入更多元件的方法”的全部內容,看起來是不是還挺簡單的,希望能對大家有幫助。

本文轉載自網路,轉載僅為分享乾貨知識,如有侵權歡迎聯絡雲豹科技進行刪除處理
原文連結:


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69996194/viewspace-2844665/,如需轉載,請註明出處,否則將追究法律責任。

相關文章