如何让Flexslider在iOS上显示不同的宽高比图像?

时间:2013-06-29 14:19:41

标签: javascript ios ipad responsive-design flexslider

我在iOS设备上遇到过Flexslider的问题,看起来与this unanswered question中报告的问题类似。具有不同宽高比的图像的幻灯片在OSX Safari和我尝试过的所有其他浏览器(甚至是IE8)上正常显示,但在iOS 5或6上使用Safari或Chrome时无法显示。 iPhone和iPad都会出现此问题。

我首先在一个大型响应式投资组合网站中注意到这一点,我正在为客户构建,并认为它可能与不寻常的配置有关,包括使用Ajax拉动滑块。事实证明,我能够将它简化为一个简单的例子。以下是iOS和OSX Safari中示例的屏幕截图。

enter image description here

示例非常简单,使用jQuery 1.10.1和jQuery.flexslider 2.1。你可以找到a working example on my website。这是代码:

<!DOCTYPE html>
<html>
    <head>
     <meta name="viewport" id="viewport" content="initial-scale=1.0, width=device-width" />
     <script src="jquery.js" type="text/javascript"></script>
     <script src="jquery.flexslider.js" type="text/javascript"></script>
     <script type="text/javascript">
        jQuery(window).load(function() {
          jQuery('.flexslider').flexslider({
             controlNav:true, 
             animationLoop: true,
             slideshowSpeed:2000
          });
        });
    </script>
    <link rel="stylesheet" href="flexslider.css" />
    <style type="text/css">
        #example{
           width:100%;
           height:auto;
           max-width:400px;
           background-color:#f0f0f0;
        }
    </style>
</head>
<body>
    <h1>Flexslider iOS bug example</h1>
        <section id="example">
            <div class="flexslider">
                <ul class="slides">
                    <li><img src="tallslide.jpg"></li>
                    <li><img src="wideslide.jpg"></li>
                </ul>
            </div>    
            <p>Text after slider</p>
        </section>
   </body>
</html>

我尝试了很多CSS调整,例如更改要显示的图像:内联,以及弄乱边距和填充。没有一个能让它变得更好。

我的问题是: 如何让Flexslider在iOS上正确显示短幻灯片,或者您知道哪个滑块在具有不同宽高比的幻灯片的响应式网站中运行良好?

3 个答案:

答案 0 :(得分:2)

Flexslider提供的内容目前看起来不像。我最好的选择是使用具有adaptiveHeight选项的BXSlider。

答案 1 :(得分:0)

如果您的图片尺寸与您需要的尺寸不同,请将容器的高度设置为固定值,并将内容设置为overflow:hidden;

这样的东西
.flexslider {
  height: 300px;
  overflow: hidden;
}

您可以根据视口的高度包含一系列媒体查询,以便在一定高度范围内调整该高度。

答案 2 :(得分:0)

那样的东西?!根据您的示例定制;)(flexslider 2.1测试)

jQuery(window).load(function() {
  jQuery('.flexslider').flexslider({
     controlNav:true, 
     animationLoop: true,
     slideshowSpeed:2000,
     after: function(slider){
       $(this).height( $(this).find('.slides > li').eq(slider.currentSlide).height() );
     }
  });
});

从我之前对此stackoverflow问题的回答https://stackoverflow.com/a/21491781/3259159