Created
August 31, 2011 11:42
-
-
Save scottjehl/1183357 to your computer and use it in GitHub Desktop.
Normalized hide address bar for iOS & Android
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
* Normalized hide address bar for iOS & Android | |
* (c) Scott Jehl, scottjehl.com | |
* MIT License | |
*/ | |
(function( win ){ | |
var doc = win.document; | |
// If there's a hash, or addEventListener is undefined, stop here | |
if( !location.hash && win.addEventListener ){ | |
//scroll to 1 | |
window.scrollTo( 0, 1 ); | |
var scrollTop = 1, | |
getScrollTop = function(){ | |
return win.pageYOffset || doc.compatMode === "CSS1Compat" && doc.documentElement.scrollTop || doc.body.scrollTop || 0; | |
}, | |
//reset to 0 on bodyready, if needed | |
bodycheck = setInterval(function(){ | |
if( doc.body ){ | |
clearInterval( bodycheck ); | |
scrollTop = getScrollTop(); | |
win.scrollTo( 0, scrollTop === 1 ? 0 : 1 ); | |
} | |
}, 15 ); | |
win.addEventListener( "load", function(){ | |
setTimeout(function(){ | |
//at load, if user hasn't scrolled more than 20 or so... | |
if( getScrollTop() < 20 ){ | |
//reset to hide addr bar at onload | |
win.scrollTo( 0, scrollTop === 1 ? 0 : 1 ); | |
} | |
}, 0); | |
} ); | |
} | |
})( this ); |
Does this work in ios6? I had a simple window.scrollTo( 0, 1 ); that works in <= ios5 but not in ios6.
Thanks, Viktor
it doesn't work.
Apparently, not working properly anymore. It adds extra padding...
does this work?
It doesn't work in Android v4.x
This is outdated. Thanks for this snippet. Works on iOS 7- only.
2020 | That does not work (
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
I swear, I cannot get any version of this to work. window.scrollTo(0,0) ; window.scrollTo(0,1) ; hideAddressBar() above ; hideaddressbar.js ; anything. here's where I'm trying it: https://beta.buildingindustryservices.com/payapp . Cannot imagine what I'm doing wrong. I keep uploading code to my server and I test it in four browsers:
I don't have an iPhone to test on.
I'm open to suggestions. I've been tweaking code to do this for 2 months (no, it's not the only thing I've been coding).