HTML5实践 -- iPhone Safari Viewport Scaling Bug
转载请注明原创地址:http://www.cnblogs.com/softlover/archive/2012/11/25/2787555.html
从事过iphone响应式设计的人,一定清楚iphone safari浏览器viewport 缩放的bug。当你将viewport的宽度设计为设备宽度,并将iphone旋转到 landscape 视图的时候,bug就会发生。你可以使用iphone访问demo地址,将视图从 portrait 切换到 landscape,来查看该bug。今天我们将尝试修复这个问题。
问题
下面截图展示了该bug。
解决方案1:使用Meta标签快读修复(demo)
一个快速的修改办法是,为viewport 设置如下属性 maximum-scale=1。副作用是,页面不能被执行缩放操作了。
<meta name="viewport" content="width=device-width; initial-scale=1; maximum-scale=1">
解决方案2:使用javascript(demo)
为了可用性的考虑,上面的办法是不可行的。我们可以在head中,通过添加下面的javascript脚本来完美的解决这个问题。脚本来源:https://gist.github.com/901295。
<script type="text/javascript"> (function(doc) { var addEvent = 'addEventListener', type = 'gesturestart', qsa = 'querySelectorAll', scales = [1, 1], meta = qsa in doc ? doc[qsa]('meta[name=viewport]') : []; function fix() { meta.content = 'width=device-width,minimum-scale=' + scales[0] + ',maximum-scale=' + scales[1]; doc.removeEventListener(type, fix, true); } if ((meta = meta[meta.length - 1]) && addEvent in doc) { fix(); scales = [.25, 1.6]; doc[addEvent](type, fix, true); } }(document)); </script>
原文地址:http://webdesignerwall.com/tutorials/iphone-safari-viewport-scaling-bug