解決 iframe 在 iPad和iPhone 上不能滾動的問題
阿新 • • 發佈:2019-01-26
今天要在web中巢狀一個網址或本地HTML,用到了iframe,在電腦上設定scrolling=‘auto’,寬度高度,會有滾動條出現。而在ipad上會全部顯示整個網頁的寬度高度。scrolling屬性無效。原來在html5中的iframe已經只有剩下src的屬性。
但是若設定scrolling=‘no’.還是會生效的。頁面只顯示定義的高度和寬度的大小。設定overflow:hidden都沒用。
怎麼讓ipad safari 中的iframe的內容在固定大小中可滾動?
網上說要用seamless屬性。直接寫個seamless。但是這個屬性ipad的safari不支援。chrome是支援的。
IE6 – Windows: no support
IE7 – Windows: no support
IE8 – Windows – Windows: no support
IE9 beta – Windows: no support
Firefox 3.6 – Windows: no support
Firefox 3.6 – OSX: no support
Firefox 4.0 – beta Windows: no support
Firefox 4.0 – beta OSX: no support
Safari OSX: no support
Chrome 7 – Windows: no support
Chrome 7 – Windows: no support
Chrome 9 – OSX: no support
Opera 11 – OSX: no support
測試例子:
http://www.maxdesign.com.au/jobs/example-seamless/
所以以上方法都無法解決ipad safari中iframe滾動的問題。
解決辦法:
在iframe外加一層div,設定樣式-webkit-overflow-scrolling:touch; overflow: scroll;
讓超出div的內容可以通過touch來滾動。
[javascript] view plain copy
最終程式碼
但是若設定scrolling=‘no’.還是會生效的。頁面只顯示定義的高度和寬度的大小。設定overflow:hidden都沒用。
怎麼讓ipad safari 中的iframe的內容在固定大小中可滾動?
網上說要用seamless屬性。直接寫個seamless。但是這個屬性ipad的safari不支援。chrome是支援的。
IE6 – Windows: no support
IE7 – Windows: no support
IE8 – Windows – Windows: no support
IE9 beta – Windows: no support
Firefox 3.6 – Windows: no support
Firefox 3.6 – OSX: no support
Firefox 4.0 – beta Windows: no support
Firefox 4.0 – beta OSX: no support
Safari OSX: no support
Chrome 7 – Windows: no support
Chrome 7 – Windows: no support
Chrome 9 – OSX: no support
Opera 11 – OSX: no support
測試例子:
http://www.maxdesign.com.au/jobs/example-seamless/
所以以上方法都無法解決ipad safari中iframe滾動的問題。
解決辦法:
在iframe外加一層div,設定樣式-webkit-overflow-scrolling:touch; overflow: scroll;
讓超出div的內容可以通過touch來滾動。
另外,如果iframe的src不是網址,而是本地的html,則需要給HTML的DOM新增監聽事件,讓html的body可以監聽到touch事件,讓巢狀的html也可以滾動。
- //如果iframe的src不是網址,而是本地的html,則需要給HTML的DOM新增監聽事件,讓html的body可以監聽到touch事件,讓巢狀的html也可以滾動。
var toScrollFrame = function(iFrame, mask) {
if (!navigator.userAgent.match(/iPad|iPhone/i))
return false;
//如果沒有iOS,什麼也不做
var mouseY = 0;
var mouseX = 0;
jQuery(iFrame).ready(function() {//等待iFrame載入
//記憶初始拖曳運動
jQuery(iFrame).contents()[0].body.addEventListener('touchstart', function(e) {
mouseY = e.targetTouches[0].pageY;
mouseX = e.targetTouches[0].pageX;
});
//基於初始拖動位置更新滾動位置
jQuery(iFrame).contents()[0].body.addEventListener('touchmove', function(e) {
e.preventDefault();
//防止整頁拖動
var box = jQuery(mask);
box.scrollLeft(box.scrollLeft() + mouseX - e.targetTouches[0].pageX);
box.scrollTop(box.scrollTop() + mouseY - e.targetTouches[0].pageY);
//MUSEX和MouSe不需要定期更新,因為當前位置
//因為滑鼠相對於Tr.IFRAMY的當前位置隨著掩碼滾動而改變。.
});
});
return true;
};
toScrollFrame('.myFrame', '.myMask');
最終程式碼
- <!DOCTYPE html>
- <html>
- <head>
- <metahttp-equiv="Content-Type"content="text/html; charset=utf-8">
- <metaname="viewport"content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0">
- <metaname="apple-mobile-web-app-capable"content="yes">
- <metaname="apple-mobile-web-app-status-bar-style"content="black">
- <title>wrapScroller demo</title>
- <linkrel="stylesheet"href="../style/wrapScroller.css"type="text/css"media="screen"/>
- <scripttype="text/javascript"src="../jquery-1.8.0.min.js"></script>
- <scripttype="text/javascript">
- </script>
- </head>
- <bodystyle="background: #ccc;">
- <div>
- HEADER - use 2 fingers to scroll contents:
- </div>
- <divid="scrollee"style="width:300px;height:300px;-webkit-overflow-scrolling:touch; overflow: scroll;">
- <iframeid="object"height="90%"width="100%"type="text/html"src="http://en.wikipedia.org/"></iframe>
- </div>
- </body>
- </html>