Skip to content

Instantly share code, notes, and snippets.

@scottjehl
Created March 16, 2012 19:25
Show Gist options
  • Star 75 You must be signed in to star a gist
  • Fork 14 You must be signed in to fork a gist
  • Save scottjehl/2051999 to your computer and use it in GitHub Desktop.
Save scottjehl/2051999 to your computer and use it in GitHub Desktop.
Reliably get viewport dimensions in JS
/*!
An experiment in getting accurate visible viewport dimensions across devices
(c) 2012 Scott Jehl.
MIT/GPLv2 Licence
*/
function viewportSize(){
var test = document.createElement( "div" );
test.style.cssText = "position: fixed;top: 0;left: 0;bottom: 0;right: 0;";
document.documentElement.insertBefore( test, document.documentElement.firstChild );
var dims = { width: test.offsetWidth, height: test.offsetHeight };
document.documentElement.removeChild( test );
return dims;
}
// Notes:
// relies on position:fixed support, but it should work in browsers that partially support position: fixed like iOS4 and such...
//sample usage: var viewportwidth = viewportSize().width;
@mzibari
Copy link

mzibari commented Mar 14, 2020

This is FANTASTIC!!!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment