欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS判斷指定dom元素是否在屏幕內(nèi)的方法實例

 更新時間:2017年01月23日 11:08:18   作者:yangchen  
做圖片滾動加載的時候會判斷圖片是否在可視區(qū)域內(nèi),如果在就加載原地址圖片,下面這篇文章就給大家介紹了利用JS判斷指定dom元素是否在屏幕內(nèi)的方法實例,需要的朋友可以參考借鑒,下面來一起看看吧。

前言

刷網(wǎng)頁的時候,有時會遇到這樣一個情景,當(dāng)某個dom元素滾到可見區(qū)域時,它就會展現(xiàn)顯示動畫,十分有趣。那么這是如何實現(xiàn)的呢?

實現(xiàn)原理

想要實現(xiàn)這個功能,就要知道具體的實現(xiàn)原理。下面直入主題。

我們通過瀏覽器在瀏覽一個網(wǎng)頁時候是這個樣子的,如圖所示


頁面的長寬,以及各dom的坐標(biāo)都是靜止的,動的是顯示窗口坐標(biāo)而已。所以明白了這個,那么判斷一個dom元素是否可見時,就十分簡單了。

我們需要知道三個坐標(biāo)就可知道當(dāng)前dom是否在可見區(qū)域內(nèi),分別是

  1. 顯示窗口的頂部坐標(biāo)
  2. 顯示窗口的底部坐標(biāo)
  3. dom元素的中心坐標(biāo)

其判斷規(guī)則就是,當(dāng)dom元素的中心坐標(biāo)的X及Y坐標(biāo)均小于顯示窗口的頂部,且大于顯示窗口的底部坐標(biāo)時,那么就可以判斷該坐標(biāo)在可見區(qū)域。

OK,那么接下來就是要知道這三個坐標(biāo)怎么計算了。

首先是窗口的頂部坐標(biāo),頂部坐標(biāo)就是頁面的滾動條滾動的距離。

其次是底部坐標(biāo),底部坐標(biāo)就是滾動條的距離加上當(dāng)前可視窗口的高度。

最后dom元素的中心距離,就是這個dom元素到最頂端的高度加上自身高度的一般。

原理就是那么的簡單有木有。

具體實現(xiàn)

明白了原理,具體實現(xiàn)起來就很簡單啦。下面直接貼上一個簡單的dom代碼做下示例,在實際的生產(chǎn)中還是要優(yōu)化的,比如初次的首屏顯示等等,這里就不贅述了。

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
</head>
<style type="text/css">
 .box {
 width: 100%;
 height: 200px;
 background: #ff0000;
 margin-bottom: 10px;
 text-align: center;
 color: #fff;
 line-height: 200px;
 font-family: microsoft yahei;
 font-size: 40px;
 
 }
 .animate{
 animation: showText 1s;
 }
 @keyframes showText
 {
 from {
 font-size: 20px;
 }
 to {
 font-size: 40px;
 }
 }
</style>
<body>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
</body>
<script type="text/javascript">
 
 var box = document.getElementsByClassName('box');
 document.addEventListener('scroll',function(){
  
  //滾動條高度+視窗高度 = 可見區(qū)域底部高度
  var visibleBottom = window.scrollY + document.documentElement.clientHeight;
  //可見區(qū)域頂部高度
  var visibleTop = window.scrollY;
  for (var i = 0; i < box.length; i++) {
  var centerY = box[i].offsetTop+(box[i].offsetHeight/2);
  if(centerY>visibleTop&&centerY<visibleBottom){
   box[i].innerHTML = '區(qū)域可見'
   box[i].setAttribute("class",'box animate')
   console.log('第'+i+'個區(qū)域可見');
  }else{
   box[i].innerHTML = '';
   box[i].setAttribute("class",'box')
   console.log('第'+i+'個區(qū)域不可見');
  }
  }
 })
</script>
</html>

效果圖

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

  • JavaScript中訪問節(jié)點對象的方法有哪些如何使用

    JavaScript中訪問節(jié)點對象的方法有哪些如何使用

    js訪問節(jié)點對象的方法有很多,比如getElementById在本文將舉例為大家介紹下
    2013-09-09
  • js 獲取元素所有兄弟節(jié)點的實現(xiàn)方法

    js 獲取元素所有兄弟節(jié)點的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猨s 獲取元素所有兄弟節(jié)點的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • JavaScript canvas復(fù)刻蘋果發(fā)布會環(huán)形進(jìn)度條

    JavaScript canvas復(fù)刻蘋果發(fā)布會環(huán)形進(jìn)度條

    canvas 真是一個好東西,它給前端插上了想象的翅膀,伴隨著 h5 而來,將 web 代入了新的領(lǐng)域。本文將利用anvas復(fù)刻蘋果發(fā)布會環(huán)形進(jìn)度條,感興趣的可以嘗試一下
    2022-07-07
  • JavaScript事件委托實例分析

    JavaScript事件委托實例分析

    這篇文章主要介紹了JavaScript事件委托的用法,以實例形式分析了javascript事件委托的實現(xiàn)方法,需要的朋友可以參考下
    2015-05-05
  • 淺談javascript中執(zhí)行環(huán)境(作用域)與作用域鏈

    淺談javascript中執(zhí)行環(huán)境(作用域)與作用域鏈

    本文主要介紹了javascript中執(zhí)行環(huán)境(作用域)與作用域鏈,并在文章結(jié)尾處做出了總結(jié),感興趣的朋友可以看下
    2016-12-12
  • JavaScript+html5 canvas繪制的小人效果

    JavaScript+html5 canvas繪制的小人效果

    這篇文章主要介紹了JavaScript+html5 canvas繪制的小人效果,涉及JavaScript結(jié)合html5 canvas圖形繪制及顏色隨機(jī)填充的技巧,需要的朋友可以參考下
    2016-01-01
  • javascript數(shù)據(jù)類型驗證方法

    javascript數(shù)據(jù)類型驗證方法

    這篇文章主要為大家分享了一個簡單的javascript數(shù)據(jù)類型驗證方法,感興趣的小伙伴們可以參考一下
    2015-12-12
  • JavaScript判斷瀏覽器及其版本信息

    JavaScript判斷瀏覽器及其版本信息

    本篇文章主要分享了通過window.navigator來判斷瀏覽器及其版本信息的實例代碼。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • Javascript自定義函數(shù)判斷網(wǎng)站訪問類型是PC還是移動終端

    Javascript自定義函數(shù)判斷網(wǎng)站訪問類型是PC還是移動終端

    如果,能夠判斷出訪問Web網(wǎng)頁的類型(PC還是移動終端)。就可以解決許多絢麗多彩的 Flash效果出不來的問題
    2014-01-01
  • 最新評論