JS判斷元素是否在可視區(qū)域技巧詳解
前言
在日常開(kāi)發(fā)中,我們經(jīng)常需要判斷目標(biāo)元素是否在視窗之內(nèi)或者和視窗的距離小于一個(gè)值(例如 100 px),從而實(shí)現(xiàn)一些常用的功能,例如:
- 圖片的懶加載
- 列表的無(wú)限滾動(dòng)
- 計(jì)算廣告元素的曝光情況
- 可點(diǎn)擊鏈接的預(yù)加載
實(shí)現(xiàn)方式
判斷一個(gè)元素是否在可視區(qū)域,我們常用的有offsetTop、scrollTop和getBoundingClientRect
offsetTop、scrollTop
offsetTop,元素的上外邊框至包含元素的上內(nèi)邊框之間的像素距離,其他offset屬性如下圖所示:

下面再來(lái)了解下clientWidth、clientHeight:
clientWidth:元素內(nèi)容區(qū)寬度加上左右內(nèi)邊距寬度,即clientWidth = content + paddingclientHeight:元素內(nèi)容區(qū)高度加上上下內(nèi)邊距高度,即clientHeight = content + padding
這里可以看到client元素都不包括外邊距
最后,關(guān)于scroll系列的屬性如下:
scrollWidth和scrollHeight主要用于確定元素內(nèi)容的實(shí)際大小scrollLeft和scrollTop屬性既可以確定元素當(dāng)前滾動(dòng)的狀態(tài),也可以設(shè)置元素的滾動(dòng)位置- 垂直滾動(dòng)
scrollTop > 0 - 水平滾動(dòng)
scrollLeft > 0
- 垂直滾動(dòng)
- 將元素的
scrollLeft和scrollTop設(shè)置為 0,可以重置元素的滾動(dòng)位置
注意
- 上述屬性都是只讀的,每次訪問(wèn)都要重新開(kāi)始
下面再看看如何實(shí)現(xiàn)判斷:
公式如下:
el.offsetTop - document.documentElement.scrollTop <= viewPortHeight
代碼實(shí)現(xiàn):
function isInViewPortOfOne (el) {
// viewPortHeight 兼容所有瀏覽器寫(xiě)法
const viewPortHeight = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight
const offsetTop = el.offsetTop
const scrollTop = document.documentElement.scrollTop
const top = offsetTop - scrollTop
return top <= viewPortHeight
}
getBoundingClientRect
返回值是一個(gè) DOMRect對(duì)象,擁有left, top, right, bottom, x, y, width, 和 height屬性
const target = document.querySelector('.target');
const clientRect = target.getBoundingClientRect();
console.log(clientRect);
// {
// bottom: 556.21875,
// height: 393.59375,
// left: 333,
// right: 1017,
// top: 162.625,
// width: 684
// }
屬性對(duì)應(yīng)的關(guān)系圖如下所示:

當(dāng)頁(yè)面發(fā)生滾動(dòng)的時(shí)候,top與left屬性值都會(huì)隨之改變
如果一個(gè)元素在視窗之內(nèi)的話,那么它一定滿(mǎn)足下面四個(gè)條件:
- top 大于等于 0
- left 大于等于 0
- bottom 小于等于視窗高度
- right 小于等于視窗寬度
實(shí)現(xiàn)代碼如下:
function isInViewPort(element) {
const viewWidth = window.innerWidth || document.documentElement.clientWidth;
const viewHeight = window.innerHeight || document.documentElement.clientHeight;
const {
top,
right,
bottom,
left,
} = element.getBoundingClientRect();
return (
top >= 0 &&
left >= 0 &&
right <= viewWidth &&
bottom <= viewHeight
);
}以上就是JS判斷元素是否在可視區(qū)域技巧詳解的詳細(xì)內(nèi)容,更多關(guān)于JS判斷元素可視區(qū)域的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
基于bootstrap實(shí)現(xiàn)bootstrap中文網(wǎng)巨幕效果
這篇文章主要介紹了基于bootstrap實(shí)現(xiàn)bootstrap中文網(wǎng)巨幕效果,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-05-05
js執(zhí)行字符串代碼的具體實(shí)現(xiàn)
這篇文章主要給大家介紹了js執(zhí)行字符串代碼的具體實(shí)現(xiàn),需要的朋友可以參考下2024-06-06
javascript中關(guān)于執(zhí)行環(huán)境的雜談
如你所知,javascript里執(zhí)行環(huán)境是作為一個(gè)最核心的概念存在的。相信廣大FE筒子們對(duì)于這個(gè)概念不會(huì)陌生,它定義了變量或函數(shù)有權(quán)訪問(wèn)其他數(shù)據(jù)范圍以及其行為。2011-08-08
解決Layui中l(wèi)ayer報(bào)錯(cuò)的問(wèn)題
今天小編就為大家分享一篇解決Layui中l(wèi)ayer報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
JavaScript實(shí)現(xiàn)通過(guò)滑塊改變網(wǎng)頁(yè)顏色
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)通過(guò)滑塊改變網(wǎng)頁(yè)顏色,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
獲取服務(wù)器傳來(lái)的數(shù)據(jù) 用JS去空格的正則表達(dá)式
獲取服務(wù)器傳來(lái)的數(shù)據(jù) 用JS去空格的正則表達(dá)式,需要的朋友可以參考下2012-03-03
ECMAScript6塊級(jí)作用域及新變量聲明(let)
這篇文章主要介紹了ECMAScript6塊級(jí)作用域及新變量聲明(let) 的相關(guān)資料,需要的朋友可以參考下2015-06-06
JavaScript使用WebSocket實(shí)現(xiàn)實(shí)時(shí)通信的技術(shù)詳解
WebSocket作為一種高效的通信協(xié)議,為開(kāi)發(fā)者提供了一種在客戶(hù)端和服務(wù)器之間進(jìn)行全雙工通信的方法,本文將深入探討WebSocket技術(shù),并提供實(shí)戰(zhàn)代碼示例2024-04-04

