隨著Web技術(shù)的不斷更新,越來越多的網(wǎng)站開始使用單頁應(yīng)用程序,這種應(yīng)用程序中,僅有一個(gè)HTML文件和JavaScript文件,但由于其設(shè)計(jì)緣由,此類網(wǎng)站中必然需要實(shí)現(xiàn)滾動(dòng)到頁面底部時(shí),自動(dòng)請(qǐng)求下一頁數(shù)據(jù)。此時(shí),我們便需要借助JavaScript實(shí)現(xiàn)頁面的向下滾動(dòng)。下文將介紹一些常見的JavaScript Downpage實(shí)現(xiàn)方式。
第一種實(shí)現(xiàn)方式:scrollTop初學(xué)者或許聽都沒聽說過scrollTop,它在JavaScript中非常常用。其用途是返回全局窗口的當(dāng)前垂直滾動(dòng)位置,可用于計(jì)算頁面的整體高度(document.body.scrollHeight)和視口高度(window.innerHeight)。因此,我們可以通過比較頁面高度和當(dāng)前滾動(dòng)高度,判定是否滾動(dòng)到了頁面最底部。
window.onscroll = function() { if ((window.innerHeight + window.pageYOffset) >= document.body.scrollHeight) { console.log("到達(dá)底部"); } }
第二種實(shí)現(xiàn)方式:Intersection Observer
在舊版的JavaScript中,對(duì)于我們觀測(cè)對(duì)象的位置,我們需要進(jìn)行周期性的計(jì)算和比對(duì),并且任何一個(gè)不必要的計(jì)算都會(huì)對(duì)性能造成影響。但I(xiàn)ntersection Observer提供了一種讓我們知道目標(biāo)元素何時(shí)進(jìn)入或離開另一個(gè)元素(一般為視口)的可見性的方法。IntersectionObserver對(duì)象是一個(gè)可以觀察另一個(gè)元素的API,如果它跨越了根元素或另外一個(gè)容器元素的邊界部分,則會(huì)執(zhí)行回調(diào)函數(shù)。
const observer = new IntersectionObserver(entries =>{ if (entries[0].isIntersecting) { console.log('到達(dá)底部'); } }); observer.observe(document.querySelector('#trigger'));
第三種實(shí)現(xiàn)方式:Vue+axios
下面,我們提供在Vue框架下使用axios實(shí)現(xiàn)DownPage的方法。在Vue框架中,提供了 $nextTick 的內(nèi)置函數(shù),而 axios 是一個(gè)易于使用且功能豐富的AJAX 庫。因此我們只需要在 $nextTick 回調(diào)函數(shù)中判斷滾動(dòng)距離是否到達(dá)頁面底部,如果是,就執(zhí)行函數(shù)提供的 nextPage() 方法即可。
nextPage() { return this.$axios.get('/path/to/next/page').then(response =>{ // 處理響應(yīng) }); }, mounted() { window.addEventListener('scroll', () =>{ if (document.documentElement.clientHeight + window.pageYOffset >= document.documentElement.scrollHeight) { this.$nextTick(() =>{ this.nextPage(); }) } }); },
綜上,我們介紹了幾種JavaScript Downpage的實(shí)現(xiàn)方式,而這些方式也并非唯一,還有很多其他的方式。在實(shí)際使用中,根據(jù)業(yè)務(wù)需求和代碼適合度的具體情況,我們需要選擇最為合適的方式,并進(jìn)行實(shí)現(xiàn)。