Scrollable iframe on mobile Safari
In order to make an iframe scrollable on iOs, you have to add the CSS3 property "-webkit-overflow-scrolling:touch" to the parent container.
<div style="overflow:auto;-webkit-overflow-scrolling:touch">
<iframe src="./yxz" style="width:100%;height:100%">
</div>
Written by Steffen Dietz
Related protips
12 Responses
Thank you! You just spared me a whole morning of groping in the dark! ;-)
Thank you! works perfectly!
data:image/s3,"s3://crabby-images/0ca75/0ca75a3adebeaa326f22910173adf917e71d0475" alt=""
Worked like a charm! Thanks!
Yesssssss! This is the simplest, best answer to this problem I've found. Thank you!
data:image/s3,"s3://crabby-images/9cbf3/9cbf34667690233ce716ddef9c4284f02df24f8d" alt=""
good one
but when i scrolling the page it jump to top page in some point,
it happened to somebody?
data:image/s3,"s3://crabby-images/ca997/ca997cc236602d917920e72413fec5cacd12dcae" alt=""
Cool! fine tanks!
data:image/s3,"s3://crabby-images/9c5dd/9c5dd2e4e8f0d210831a9b8309adb4f21f79cd78" alt=""
Great! You saved my time! Thanks!
data:image/s3,"s3://crabby-images/b9fb5/b9fb527e270ede4b00432b56e2cc70411fd290cb" alt=""
Awesome! working fine. Thanks!
data:image/s3,"s3://crabby-images/b36e7/b36e78eca2a70ae8dc3aeef78b4531d8938bea19" alt=""
I have the same issue for jump back to top when touch the page at some point. Anyone solve this issue? Thanks.
data:image/s3,"s3://crabby-images/c684a/c684ae3b8544077905f9c427eeabcd0287bcf855" alt=""
I don't think this works: http://output.jsbin.com/sesenuziri
data:image/s3,"s3://crabby-images/597f2/597f2d1c20d12a742ab1001a33d900a06e3a591e" alt=""
It will jump to the top any time the iframe content changes. The only workaround that I can find is to explicitly set the height of the iframe to the height of the contents. Something like this (using jQuery).
$('iframe').load(function() {
var self = this;
var oldHeight = 0;
function resizeiframe(eventObject) {
var newHeight = $(self.contentWindow.document).height();
if (newHeight !== oldHeight) {
oldHeight = newHeight;
$(self).css("height", newHeight);
}
}
resizeiframe();
$(self.contentWindow).resize(resizeiframe);
});
Awesome that worked perfectly for iphone!! What would the equivalent be for android?