Mat*_*vić 17 css 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, 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>
</ul>
Run Code Online (Sandbox Code Playgroud)
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();
});
Run Code Online (Sandbox Code Playgroud)
谢谢.
小智 51
可能是你太早调用bxSlider函数.如果你正在调用它
$(document).ready(function() { ... });
考虑改为使用
$(window).load(function() { ... });
使用这两个函数之间的区别在于(document).ready等待DOM向用户显示初始状态,而(window).load实际上等待直到所有资源都加载到DOM上.
小智 7
您可以使用
slider=jQuery('.seminars-slider').bxSlider({
mode: 'vertical',
controls:false,
pager:false,
minSlides:2,
maxSlides:2,
moveSlides:1
});
setTimeout(function(){
slider.redrawSlider();
},100);
Run Code Online (Sandbox Code Playgroud)