jquery – bxslider在加载时计算错误的视口大小

前端之家收集整理的这篇文章主要介绍了jquery – bxslider在加载时计算错误的视口大小前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
无论如何,我最近开始使用bxslider,我有一个问题。

似乎在页面加载时错误地计算其视口大小,这意味着它在移动设备,平板电脑等上不能正常工作。

奇怪的是,当我调整浏览器的窗口大小(甚至只是一个像素)时,视口高度得到正确的计算,一切都看起来不错。但是如果我刷新具有相同高度和宽度的页面,则无法正确计算bx-viewport。

任何想法为什么会发生这种情况?

HTML看起来像这样(是的,我知道它可能没有任何关系,但仍然):

<ul class="seminars-slider">
    <li>
        <article class="education-article">
            <h3><a href="#"> Sit tincidunt eros massa,lundium ultrices,sit in aliquet velit</a></h3>
            <p>LOL1</p>
            <div class="buttons">
                <a href="#" class="book-button"><span>Book now</span></a>
                <a href="#" class="read-more"><span>Read more</span></a>
            </div>
            <div class="clearall"></div>

        </article>
    <div class="clearall"></div>
    </li>

    // same li
    <li>
        <article class="education-article">
            <h3><a href="#"> Sit tincidunt eros massa,sit in aliquet velit</a></h3>
            <p>LOL1</p>
            <div class="buttons">
                <a href="#" class="book-button"><span>Book now</span></a>
                <a href="#" class="read-more"><span>Read more</span></a>
            </div>
            <div class="clearall"></div>

        </article>
    <div class="clearall"></div>
    </li>
</ul>

js调用看起来像:

slider=jQuery('.seminars-slider').bxSlider({
    mode: 'vertical',controls:false,pager:false,minSlides:2,maxSlides:2,moveSlides:1
});

jQuery('.up-control').click(function() {
    slider.goToNextSlide();
});
jQuery('.down-control').click(function() {
    slider.goToPrevSlide();
});

谢谢。

解决方法

这可能是你早点调用bxSlider函数。如果你正在调用

$(document).ready(function(){…});

考虑使用

$(window).load(function(){…});

使用这两个函数之间的区别是(document).ready等待,直到DOM被显示用户的初始状态,而(window).load实际上等待直到所有资源都被加载到DOM上。

猜你在找的jQuery相关文章