2021-01-06如何優(yōu)雅的判斷元素是否進(jìn)入當(dāng)前視區(qū)

圖片

正文

  1. 使用元素位置判斷元素是否在當(dāng)前視區(qū)

這種方法實(shí)現(xiàn)起來比較簡單庭瑰, 我們一步一步來。
首先:編寫一個 util 函數(shù) isVisible沐绒,它將僅接收一個參數(shù)犁柜,即 element剖毯。

export const isVisible = (el) => { };

使用 getBoundingClientRect 獲取該元素的位置

const rect = el.getBoundingClientRect();

將找到窗口的高度和寬度

const vWidth = window.innerWidth || document.documentElement.clientWidth;


const vHeight = window.innerHeight || document.documentElement.clientHeight;

再編寫一個函數(shù)圾笨,該函數(shù)基本上將接收 x 和 y 點(diǎn),并使用elementFromPoint函數(shù)返回元素速兔。

const elementFromPoint = function (x, y) { 
  return document.elementFromPoint(x, y); 
};

檢查元素是否在窗口內(nèi):

// Return false if it's not in the viewport
if (rect.right < 0 
  || rect.bottom < 0
  || rect.left > vWidth 
  || rect.top > vHeight) { 
  return false; 
}

邊界檢查:

// Return true if any of its four corners are visible
 return (
   el.contains(elementFromPoint(rect.left, rect.top))
   || el.contains(efp(rect.right, rect.top))
   || el.contains(efp(rect.right, rect.bottom))
   || el.contains(efp(rect.left, rect.bottom))
 );

完整代碼:

export const isVisible = (el) => {
  const rect = el.getBoundingClientRect();
  const vWidth = window.innerWidth || document.documentElement.clientWidth;
  const vHeight = window.innerHeight || document.documentElement.clientHeight;
  const efp = function (x, y) { return document.elementFromPoint(x, y); };

  // Return false if it's not in the viewport
  if (rect.right < 0 || rect.bottom < 0
            || rect.left > vWidth || rect.top > vHeight) { return false; }

  // Return true if any of its four corners are visible
  return (
    el.contains(
      elementFromPoint(rect.left, rect.top))
      || el.contains(efp(rect.right, rect.top))
      || el.contains(efp(rect.right, rect.bottom))
      || el.contains(efp(rect.left, rect.bottom))
  );
};

用法:

import { isVisible } from '../utils';
// ...
const ele = document.getElementById(id);
return isVisible(ele);

邏輯并不復(fù)雜墅拭,不過多介紹。

鏈接https://mp.weixin.qq.com/s/dYRCeLORlaiCzNgITniYZA

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末涣狗,一起剝皮案震驚了整個濱河市谍婉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌镀钓,老刑警劉巖穗熬,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異丁溅,居然都是意外死亡唤蔗,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門窟赏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來妓柜,“玉大人,你說我怎么就攤上這事涯穷」髌” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵拷况,是天一觀的道長作煌。 經(jīng)常有香客問我掘殴,道長,這世上最難降的妖魔是什么粟誓? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任奏寨,我火速辦了婚禮,結(jié)果婚禮上鹰服,老公的妹妹穿的比我還像新娘病瞳。我一直安慰自己,他們只是感情好获诈,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布仍源。 她就那樣靜靜地躺著,像睡著了一般舔涎。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上逗爹,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天亡嫌,我揣著相機(jī)與錄音,去河邊找鬼掘而。 笑死挟冠,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的袍睡。 我是一名探鬼主播知染,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼斑胜!你這毒婦竟也來了控淡?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤止潘,失蹤者是張志新(化名)和其女友劉穎掺炭,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體凭戴,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡涧狮,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了么夫。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片者冤。...
    茶點(diǎn)故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖档痪,靈堂內(nèi)的尸體忽然破棺而出涉枫,到底是詐尸還是另有隱情,我是刑警寧澤钞它,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布拜银,位于F島的核電站殊鞭,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏尼桶。R本人自食惡果不足惜操灿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望泵督。 院中可真熱鬧趾盐,春花似錦、人聲如沸小腊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽秩冈。三九已至本缠,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間入问,已是汗流浹背丹锹。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留芬失,地道東北人楣黍。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像棱烂,于是被迫代替她去往敵國和親租漂。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容