JavaScript中DOM尺寸測(cè)量與節(jié)流技巧總結(jié)
前言
在開發(fā)網(wǎng)頁時(shí),我們經(jīng)常需要獲取元素的寬高,或者處理一些像滾動(dòng)、窗口調(diào)整這樣的事件。不過,如果不加以優(yōu)化,頻繁觸發(fā)這些事件可能會(huì)影響頁面性能。今天這篇文章會(huì)介紹如何通過 JavaScript 獲取 DOM 元素的尺寸,同時(shí)聊聊如何使用節(jié)流(Throttle)來優(yōu)化高頻事件處理,讓你的網(wǎng)頁跑得更流暢。
一、如何獲取元素的尺寸
JavaScript 提供了不少方法來獲取元素的寬度和高度,下面是幾個(gè)常用的。
1. Element.clientHeight 和 Element.clientWidth
clientHeight
:返回元素的高度,包括padding
,但不包括border
、margin
和滾動(dòng)條。clientWidth
:返回元素的寬度,邏輯跟clientHeight
類似。
這些屬性很適合用來獲取元素的實(shí)際可見區(qū)域,比如你需要知道某個(gè)元素在頁面上占了多大的空間。
// 獲取瀏覽器視口的高度 let viewportHeight = document.documentElement.clientHeight; // 獲取某個(gè)元素的寬度 let elementWidth = document.querySelector('.my-element').clientWidth;
2. Element.scrollHeight 和 Element.scrollWidth
這兩個(gè)屬性代表元素的總高度和總寬度,包括那些超出可視范圍的內(nèi)容,適用于有滾動(dòng)條的元素。
// 獲取頁面的總高度 let pageHeight = document.documentElement.scrollHeight; // 獲取某個(gè)滾動(dòng)區(qū)域的總寬度 let elementScrollWidth = document.querySelector('.scrollable-element').scrollWidth;
3. Element.scrollTop 和 Element.scrollLeft
scrollTop
:表示已經(jīng)向下滾動(dòng)了多少像素。scrollLeft
:表示已經(jīng)向右滾動(dòng)了多少像素。
這兩個(gè)屬性經(jīng)常用來監(jiān)聽滾動(dòng)事件,比如你想在用戶滾動(dòng)到一定位置時(shí)觸發(fā)加載更多內(nèi)容。
// 獲取當(dāng)前頁面滾動(dòng)的垂直距離 let scrollTop = document.documentElement.scrollTop;
二、節(jié)流(Throttle)與防抖(Debounce)
在開發(fā)中,像滾動(dòng)、窗口調(diào)整這樣的事件有時(shí)候觸發(fā)得非常頻繁。如果每次事件觸發(fā)都去執(zhí)行某些耗時(shí)操作,頁面可能會(huì)變得很卡。這時(shí)我們可以使用節(jié)流和防抖來優(yōu)化這些操作。
1. 節(jié)流(Throttle)
節(jié)流的作用是讓某個(gè)函數(shù)在固定時(shí)間內(nèi)只能執(zhí)行一次。不管這個(gè)時(shí)間段內(nèi)事件被觸發(fā)了多少次,函數(shù)都只會(huì)在時(shí)間間隔內(nèi)執(zhí)行一次。
function throttle(fn, delay) { let valid = true; return function() { if (!valid) { return; } valid = false; setTimeout(() => { fn(); valid = true; }, delay); }; } // 示例:每隔 300 毫秒打印一次滾動(dòng)條的位置 function showScrollPosition() { let scrollTop = document.documentElement.scrollTop; console.log('滾動(dòng)條位置:' + scrollTop); } window.onscroll = throttle(showScrollPosition, 300);
2. 節(jié)流和防抖的應(yīng)用場(chǎng)景
- 搜索框:當(dāng)用戶在搜索框中輸入時(shí),使用節(jié)流來減少過于頻繁的請(qǐng)求,比如每隔 500 毫秒發(fā)送一次請(qǐng)求。
- 窗口調(diào)整(resize):在頁面調(diào)整大小時(shí),通常我們只想在用戶停止調(diào)整后執(zhí)行一次操作,這時(shí)候可以使用防抖。
總結(jié)
今天通過 JavaScript 獲取 DOM 元素的尺寸,以及使用節(jié)流(Throttle)來優(yōu)化高頻事件處理的內(nèi)容到此為止
到此這篇關(guān)于JavaScript中DOM尺寸測(cè)量與節(jié)流技巧的文章就介紹到這了,更多相關(guān)JS中DOM尺寸測(cè)量與節(jié)流內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js實(shí)現(xiàn)分享到隨頁面滾動(dòng)而滑動(dòng)效果的方法
這篇文章主要介紹了js實(shí)現(xiàn)分享到隨頁面滾動(dòng)而滑動(dòng)效果的方法,實(shí)例分析了javascript操作頁面元素滾動(dòng)效果的方法,需要的朋友可以參考下2015-04-04javascript實(shí)現(xiàn)輪顯新聞標(biāo)題鏈接
這篇文章主要介紹了javascript實(shí)現(xiàn)輪顯新聞標(biāo)題鏈接的相關(guān)資料,需要的朋友可以參考下2007-08-08使用RN Animated做一個(gè)“添加購物車”動(dòng)畫的方法
這篇文章主要介紹了使用RN Animated做一個(gè)“添加購物車”動(dòng)畫的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-09-09JavaScript 高級(jí)篇之閉包、模擬類,繼承(五)
本篇主要分享我對(duì)閉包的理解及使用閉包完成私有屬性、模擬類、繼承等,結(jié)合大量例子,希望大家能快速掌握!首先讓我們先從一些基本的術(shù)語開始吧2012-04-04用原生js統(tǒng)計(jì)文本行數(shù)的簡(jiǎn)單示例
這篇文章我們來看看如何利用原生的JavaScript實(shí)現(xiàn)統(tǒng)計(jì)文本的行數(shù),代碼實(shí)現(xiàn)起來很簡(jiǎn)單,有需要的可以參考借鑒。2016-08-08微信小程序個(gè)人中心的列表控件實(shí)現(xiàn)代碼
這篇文章主要介紹了微信小程序個(gè)人中心的列表控件實(shí)現(xiàn)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04純js實(shí)現(xiàn)倒計(jì)時(shí)功能
本文主要介紹了通過js實(shí)現(xiàn)頁面的倒計(jì)時(shí)功能的思路與方法,具有一定的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01