Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Get the visible height of a div with jQuery

I need to retrieve the visible height of a div within a scrollable area. I consider myself pretty decent with jQuery, but this is completely throwing me off.

Let's say I've got a red div within a black wrapper:

In the graphic above, the jQuery function would return 248, the visible portion of the div.

Once the user scrolls past the top of the div, as in the above graphic, it would report 296.

Now, once the user has scrolled past the div, it would again report 248.

Obviously my numbers aren't going to be as consistent and clear as they are in this demo, or I'd just hard code for those numbers.

I have a bit of a theory:

  • Get the height of the window
  • Get the height of the div
  • Get the initial offset of the div from the top of the window
  • Get the offset as the user scrolls.
    • If the offset is positive, it means the top of the div is still visible.
    • if it's negative, the top of the div has been eclipsed by the window. At this point, the div could either be taking up the whole height of the window, or the bottom of the div could be showing
    • If the bottom of the div is showing, figure out the gap between it and the bottom of the window.

It seems pretty simple, but I just can't wrap my head around it. I'll take another crack tomorrow morning; I just figured some of you geniuses might be able to help.

Thanks!

UPDATE: I figured this out on my own, but looks like one of the answers below is more elegant, so I'll be using that instead. For the curious, here's what I came up with:

$(document).ready(function() {     var windowHeight = $(window).height();     var overviewHeight = $("#overview").height();     var overviewStaticTop = $("#overview").offset().top;     var overviewScrollTop = overviewStaticTop - $(window).scrollTop();     var overviewStaticBottom = overviewStaticTop + $("#overview").height();     var overviewScrollBottom = windowHeight - (overviewStaticBottom - $(window).scrollTop());     var visibleArea;     if ((overviewHeight + overviewScrollTop) < windowHeight) {         // alert("bottom is showing!");         visibleArea = windowHeight - overviewScrollBottom;         // alert(visibleArea);     } else {         if (overviewScrollTop < 0) {             // alert("is full height");             visibleArea = windowHeight;             // alert(visibleArea);         } else {             // alert("top is showing");             visibleArea = windowHeight - overviewScrollTop;             // alert(visibleArea);         }     } }); 
like image 609
JacobTheDev Avatar asked Jul 15 '14 21:07

JacobTheDev


People also ask

How can get current height of div in jQuery?

Method 1: The height() method returns the first matched element's height, But the height(value) method sets all matched elements height. // Returns the height of the first matched element $(selector). height() // Set the height of the all matched elements $(selector). height(value);

How do I make my window visible height?

$(window). height() gives you the height of the view pane. $(window). height() works better as it's cross-browser.

How does jQuery calculate window height?

Basically, $(window). height() give you the maximum height inside of the browser window (viewport), and $(document). height() gives you the height of the document inside of the browser. Most of the time, they will be exactly the same, even with scrollbars.

Which jQuery method would change the height of the 1st and 3rd row in the table?

jQuery height() Method The height() method sets or returns the height of the selected elements.


1 Answers

Calculate the amount of px an element (height) is in viewport

Fiddle demo

This tiny function will return the amount of px an element is visible in the (vertical) Viewport:

function inViewport($el) {     var elH = $el.outerHeight(),         H   = $(window).height(),         r   = $el[0].getBoundingClientRect(), t=r.top, b=r.bottom;     return Math.max(0, t>0? Math.min(elH, H-t) : Math.min(b, H)); } 

Use like:

$(window).on("scroll resize", function(){   console.log( inViewport($('#elementID')) ); // n px in viewport }); 

that's it.


jQuery .inViewport() Plugin

jsFiddle demo

from the above you can extract the logic and create a plugin like this one:

/**  * inViewport jQuery plugin by Roko C.B.  * http://stackoverflow.com/a/26831113/383904  * Returns a callback function with an argument holding  * the current amount of px an element is visible in viewport  * (The min returned value is 0 (element outside of viewport)  */ ;(function($, win) {   $.fn.inViewport = function(cb) {      return this.each(function(i,el) {        function visPx(){          var elH = $(el).outerHeight(),              H = $(win).height(),              r = el.getBoundingClientRect(), t=r.top, b=r.bottom;          return cb.call(el, Math.max(0, t>0? Math.min(elH, H-t) : Math.min(b, H)));          }        visPx();        $(win).on("resize scroll", visPx);      });   }; }(jQuery, window)); 

Use like:

$("selector").inViewport(function(px) {   console.log( px ); // `px` represents the amount of visible height   if(px > 0) {     // do this if element enters the viewport // px > 0   }else{     // do that if element exits  the viewport // px = 0   } }); // Here you can chain other jQuery methods to your selector 

your selectors will dynamically listen to window scroll and resize but also return the initial value on DOM ready trough the first callback function argument px.

like image 158
Roko C. Buljan Avatar answered Oct 06 '22 00:10

Roko C. Buljan