解决 iframe 在 iPad和iPhone 上不能滚动的问题 解决 iframe 在 iPad 上不能滚动的问题

解决 iframe 在 iPad 上不能滚动的问题

今天要在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来滚动。 

另外,如果iframe的src不是网址,而是本地的html,则需要给HTML的DOM添加监听事件,让html的body可以监听到touch事件,让嵌套的html也可以滚动。

[javascript]  view plain  copy
  1. var toScrollFrame = function(iFrame, mask) {  
  2.                     if (!navigator.userAgent.match(/iPad|iPhone/i))  
  3.                         return false;  
  4.                     //do nothing if not iOS devie  
  5.   
  6.                     var mouseY = 0;  
  7.                     var mouseX = 0;  
  8.                     jQuery(iFrame).ready(function() {//wait for iFrame to load  
  9.                         //remeber initial drag motition  
  10.                         jQuery(iFrame).contents()[0].body.addEventListener('touchstart'function(e) {  
  11.                             mouseY = e.targetTouches[0].pageY;  
  12.                             mouseX = e.targetTouches[0].pageX;  
  13.                         });  
  14.   
  15.                         //update scroll position based on initial drag position  
  16.                         jQuery(iFrame).contents()[0].body.addEventListener('touchmove'function(e) {  
  17.                             e.preventDefault();  
  18.                             //prevent whole page dragging  
  19.   
  20.                             var box = jQuery(mask);  
  21.                             box.scrollLeft(box.scrollLeft() + mouseX - e.targetTouches[0].pageX);  
  22.                             box.scrollTop(box.scrollTop() + mouseY - e.targetTouches[0].pageY);  
  23.                             //mouseX and mouseY don't need periodic updating, because the current position  
  24.                             //of the mouse relative to th iFrame changes as the mask scrolls it.  
  25.                         });  
  26.                     });  
  27.   
  28.                     return true;  
  29.                 };  
  30.   
  31.                 toScrollFrame('.myFrame''.myMask');  

最终代码 

[html]  view plain  copy
  1. <!DOCTYPE html>  
  2. <html>  
  3.     <head>  
  4.         <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  5.         <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0">  
  6.         <meta name="apple-mobile-web-app-capable" content="yes">  
  7.         <meta name="apple-mobile-web-app-status-bar-style" content="black">  
  8.         <title>wrapScroller demo</title>  
  9.         <link rel="stylesheet" href="../style/wrapScroller.css" type="text/css" media="screen" />  
  10.         <script type="text/javascript" src="../jquery-1.8.0.min.js"></script>  
  11.         <script type="text/javascript">  
  12.               
  13.         </script>  
  14.     </head>  
  15.     <body style="background: #ccc;">  
  16.         <div>  
  17.             HEADER - use 2 fingers to scroll contents:  
  18.         </div>  
  19.         <div id="scrollee" style="width:300px;height:300px;-webkit-overflow-scrolling:touch; overflow: scroll;">  
  20.             <iframe id="object" height="90%" width="100%" type="text/html" src="http://en.wikipedia.org/"></iframe>  
  21.         </div>  
  22.     </body>  
  23. </html>  


猜你喜欢

转载自blog.csdn.net/Abraham_bug/article/details/80053210