亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用vue實(shí)現(xiàn)滑動(dòng)滾動(dòng)條來加載數(shù)據(jù)

 更新時(shí)間:2023年10月26日 11:12:00   作者:itclanCoder  
在vuejs中,我們經(jīng)常使用axios來請求數(shù)據(jù),但是有時(shí)候,我們請求的數(shù)據(jù)量很大,那么我們?nèi)绾螌?shí)現(xiàn)滑動(dòng)滾動(dòng)條來加載數(shù)據(jù)呢,接下來小編就給大家介紹一下在vuejs中如何實(shí)現(xiàn)滑動(dòng)滾動(dòng)條來動(dòng)態(tài)加載數(shù)據(jù),需要的朋友可以參考下

實(shí)現(xiàn)思路

  • 首先,我們需要在vuejs中引入axios
  • 然后,我們需要從vue中,引入onMounted,onUnmounted生命周期鉤子函數(shù) 然后,我們需要在onMounted函數(shù)中,進(jìn)行監(jiān)聽 而在onUnmounted函數(shù)中,我們需要取消監(jiān)聽,解綁
  • 編寫事件處理函數(shù)handleScroll, 獲取變量scrollTop是滾動(dòng)條滾動(dòng)時(shí),距離頂部的距離,獲取變量scrollHeight是滾動(dòng)條的總高度,獲取變量clientHeight是滾動(dòng)條可視區(qū)域的高度
  • 當(dāng)滾動(dòng)條到達(dá)底部,并且距離底部小于10px時(shí),加載數(shù)據(jù),也就是請求axios數(shù)據(jù),頁碼++,重新加載數(shù)據(jù)函數(shù)
  • 為了防止用戶頻繁觸發(fā)下拉滑動(dòng)滾動(dòng)條,往往需要添加一個(gè)函數(shù)防抖,在指定的時(shí)間內(nèi),只執(zhí)行最后一次事件處理函數(shù),避免頻繁請求數(shù)據(jù),給服務(wù)器造成壓力

代碼實(shí)現(xiàn)

<template>
    <div>
          <div>
            <el-button type="primary"  @click="handleBtnGetJoke">請求數(shù)據(jù)</el-button>
            <el-button type="danger" @click="handleBtnClearData" v-if="aDatas.length > 0?true:false">清空數(shù)據(jù)</el-button>
          </div>  
          <div>
            <ul v-if="aDatas.length > 0?true:false">
                <li class="joke-list" v-for="item in aDatas"
                                    :key="item.hashId">{{ item.content }}
                </li>
                <div class="loading" v-if="aDatas.length > 0?true:false"> 
                    <el-button size="mini"  type="primary" @click="handleBtnLoading" >加載</el-button>
                </div>
            </ul> 
          </div>
    </div>
</template>

<script setup>
import axios from "axios";
import { ref,onMounted,onUnmounted  } from "vue";

let aDatas = ref([]);
let page = ref(1);
let pagesize = ref(20);

onMounted(() => {
    // 獲取數(shù)據(jù)
    handleBtnGetJoke();
    window.addEventListener('scroll', debounce(handleScroll,500));
})

onUnmounted(() => {
    window.removeEventListener('scroll', handleScroll);
})

// 事件處理函數(shù)
function handleScroll() {
    // 變量scrollTop是滾動(dòng)條滾動(dòng)時(shí),距離頂部的距離
    const scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
    // 變量scrollHeight是滾動(dòng)條的總高度
    const scrollHeight = document.documentElement.scrollHeight || document.body.scrollHeight;
     // 變量clientHeight是滾動(dòng)條可視區(qū)域的高度
    const clientHeight = document.documentElement.clientHeight || document.body.clientHeight;
     // 當(dāng)滾動(dòng)條到達(dá)底部,并且距離底部小于10px時(shí),加載數(shù)據(jù)   
    if (scrollTop + clientHeight - scrollHeight <= 10) {
        page.value++;
        handleBtnGetJoke();
    }
}

// 函數(shù)的防抖
function  debounce(method, duration) {
         var timer = null;
         return function(){
            var that = this,
                args = arguments;
            // 在本次調(diào)用之間的一個(gè)間隔時(shí)間內(nèi)若有方法在執(zhí)行,則終止該方法的執(zhí)行
            if(timer) {
              clearTimeout(timer);
            }
            // 開始執(zhí)行本次調(diào)用
            timer = setTimeout(function(){
              method.apply(that,args);
            }, duration)
          }

  }


async function handleBtnGetJoke() {
    const params = {
        key: 'aa1b7ad08be2a09a4e0d2d46897e2dc8',
        page: page.value,
        pagesize:pagesize.value,
        time: 1418816972
    }

    const response =  await axios.get('/api/joke/content/text.php',{params})
    console.log(response);
    if(response.status == 200) {
        const { data } = response.data.result;
        console.log(data);
        aDatas.value = aDatas.value.concat(data);
        if(page.value*pagesize.value >= data.length) {
            alert("沒有更多數(shù)據(jù)了")
        }

    }
}

// 加載數(shù)據(jù),疊加
function handleBtnLoading() {
    page.value++;
    handleBtnGetJoke(); 
}

// 清空數(shù)據(jù)
function handleBtnClearData() {
    aDatas.value = [];
}


</script>

<style scoped>
.joke-list {
    list-style-type: decimal;
    list-style-position: outside;
    padding: 5px 0;
    border-bottom: dashed 1px #ccc;
}

.loading {
    margin: 0 auto;
    text-align:center;
}
</style>

其中核心防抖函數(shù)如下所示,實(shí)現(xiàn)方式也很簡單,就是利用定時(shí)器,在規(guī)定的時(shí)間內(nèi),如果再次觸發(fā),則清除定時(shí)器,重新開始計(jì)時(shí)。

只執(zhí)行最后一次

// 函數(shù)的防抖
function  debounce(method, duration) {
         var timer = null;
         return function(){
            var that = this,
                args = arguments;
            // 在本次調(diào)用之間的一個(gè)間隔時(shí)間內(nèi)若有方法在執(zhí)行,則終止該方法的執(zhí)行
            if(timer) {
              clearTimeout(timer);
            }
            // 開始執(zhí)行本次調(diào)用
            timer = setTimeout(function(){
              method.apply(that,args);
            }, duration)
          }

  }

至于怎么樣判斷數(shù)據(jù)是否加載完畢,到最后一頁

每次在請求完成數(shù)據(jù)的時(shí)候去判斷一下當(dāng)前的 page × pagesize是否已經(jīng)大于等于接口返回的total值就行了,也可以是pageNum 等于total 的時(shí)候,就說明已經(jīng)沒有數(shù)據(jù)了,可以提示用戶了

if(page.value*pagesize.value >= data.length) {
            alert("沒有更多數(shù)據(jù)了")
}

總結(jié)

其實(shí)這個(gè)功能很簡單,但是寫起來還是有點(diǎn)麻煩,因?yàn)樯婕暗疆惒秸埱螅孕枰袛鄶?shù)據(jù)是否加載完畢,還要判斷是否最后一頁,還要判斷是否還有數(shù)據(jù),還要判斷是否需要提示用戶沒有更多數(shù)據(jù)了,所以代碼量還是挺多的,但是寫完之后,感覺還是挺有成就感的。

什么上拉,下拉刷新,下拉加載更多,其實(shí)原理都差不多,都是利用了防抖函數(shù),然后利用定時(shí)器,在規(guī)定的時(shí)間內(nèi),如果再次觸發(fā),則清除定時(shí)器,重新開始計(jì)時(shí)。 實(shí)現(xiàn)方式都差不多

以上就是vuejs實(shí)現(xiàn)滑動(dòng)滾動(dòng)條來加載數(shù)據(jù)的詳細(xì)內(nèi)容,更多關(guān)于vuejs滾動(dòng)條加載數(shù)據(jù)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解VUE項(xiàng)目中安裝和使用vant組件

    詳解VUE項(xiàng)目中安裝和使用vant組件

    這篇文章主要介紹了VUE安裝和使用vant組件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Vue 全家桶實(shí)現(xiàn)移動(dòng)端酷狗音樂功能

    Vue 全家桶實(shí)現(xiàn)移動(dòng)端酷狗音樂功能

    這篇文章主要介紹了Vue 全家桶實(shí)現(xiàn)移動(dòng)端酷狗音樂功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-11-11
  • Vue.js 實(shí)現(xiàn)微信公眾號(hào)菜單編輯器功能(二)

    Vue.js 實(shí)現(xiàn)微信公眾號(hào)菜單編輯器功能(二)

    這篇文章主要介紹了Vue.js 實(shí)現(xiàn)微信公眾號(hào)菜單編輯器功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2018-05-05
  • Vue3基礎(chǔ)篇之常用的循環(huán)示例詳解

    Vue3基礎(chǔ)篇之常用的循環(huán)示例詳解

    filter?方法會(huì)創(chuàng)建一個(gè)新的數(shù)組,其中包含滿足指定條件的所有元素,這個(gè)方法非常適合循環(huán)遍歷數(shù)組并根據(jù)特定條件過濾元素的情況,這篇文章主要介紹了Vue3基礎(chǔ)[常用的循環(huán)],需要的朋友可以參考下
    2024-01-01
  • Vue源碼學(xué)習(xí)之初始化模塊init.js解析

    Vue源碼學(xué)習(xí)之初始化模塊init.js解析

    本篇文章主要介紹了Vue源碼學(xué)習(xí)之初始化模塊init.js解析,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11
  • vue實(shí)現(xiàn)路由懶加載的3種方法示例

    vue實(shí)現(xiàn)路由懶加載的3種方法示例

    這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)路由懶加載的3種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • vue中的v-model原理,與組件自定義v-model詳解

    vue中的v-model原理,與組件自定義v-model詳解

    這篇文章主要介紹了vue中的v-model原理,與組件自定義v-model詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 如何在Vue中抽離接口配置文件

    如何在Vue中抽離接口配置文件

    這篇文章主要介紹了Vue中抽離接口配置文件的問題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-10-10
  • vue3-vue-router創(chuàng)建靜態(tài)路由和動(dòng)態(tài)路由方式

    vue3-vue-router創(chuàng)建靜態(tài)路由和動(dòng)態(tài)路由方式

    這篇文章主要介紹了vue3-vue-router創(chuàng)建靜態(tài)路由和動(dòng)態(tài)路由方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 基于vite2+vue3制作個(gè)招財(cái)貓游戲

    基于vite2+vue3制作個(gè)招財(cái)貓游戲

    端午將至,大家都開始吃粽子了么?本文將用vite2與vue3開發(fā)出一個(gè)招財(cái)貓小游戲,在圖案不停滾動(dòng)的同時(shí)選出可以轉(zhuǎn)出不同的素材最終得到粽子獎(jiǎng)勵(lì),康康你能用多少次才會(huì)轉(zhuǎn)出自己喜愛口味的粽子吧
    2022-05-05

最新評論