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

posted @ 2012-12-01 11:57 下一站永远 阅读(...) 评论(...) 编辑 收藏