这是一款效果非常炫酷的jQuery支持触摸屏的全屏响应式幻灯片特效。该幻灯片特效在大屏幕中显示信息的方式和小屏幕有所不同。它支持使用鼠标拖拽或在触摸屏中用手指滑动的方式来切换图片。同时带有一点视觉差效果,效果非常不错。
使用方法
HTML结构
该全屏响应式幻灯片特效的HTML结构如下:
<div class="slider-container">
<div class="slider-control left inactive"></div>
<div class="slider-control right"></div>
<ul class="slider-pagi"></ul>
<div class="slider">
<div class="slide slide-0 active">
<div class="slide__bg"></div>
<div class="slide__content">
<svg class="slide__overlay" viewBox="0 0 720 405" preserveAspectRatio="xMaxYMax slice">
<path class="slide__overlay-path" d="M0,0 150,0 500,405 0,405" />
</svg>
<div class="slide__text">
<h2 class="slide__text-heading">Project name 1</h2>
<p class="slide__text-desc">....</p>
<a class="slide__text-link">Project link</a>
</div>
</div>
</div>
......
</div>
</div>
JAVASCRIPT
用于驱动这个全屏响应式幻灯片特效的jQuery代码仅仅100多行,非常简单。其中autoSlide()方法用于幻灯片的自动播放。
function autoSlide() {
autoSlideTimeout = setTimeout(function () {
curSlide++;
if (curSlide > numOfSlides)
curSlide = 0;
changeSlides();
}, autoSlideDelay);
}
changeSlides()方法用于切换幻灯片。
function changeSlides(instant) {
if (!instant) {
animating = true;
manageControls();
$slider.addClass('animating');
$slider.css('top');
$('.slide').removeClass('active');
$('.slide-' + curSlide).addClass('active');
setTimeout(function () {
$slider.removeClass('animating');
animating = false;
}, animTime);
}
window.clearTimeout(autoSlideTimeout);
$('.slider-pagi__elem').removeClass('active');
$('.slider-pagi__elem-' + curSlide).addClass('active');
$slider.css('transform', 'translate3d(' + -curSlide * 100 + '%,0,0)');
$slideBGs.css('transform', 'translate3d(' + curSlide * 50 + '%,0,0)');
diff = 0;
autoSlide();
}
然后分别使用navigateLeft()和navigateRight()方法来控制向左或向右切换幻灯片。
function navigateLeft() {
if (animating)
return;
if (curSlide > 0)
curSlide--;
changeSlides();
}
function navigateRight() {
if (animating)
return;
if (curSlide < numOfSlides)
curSlide++;
changeSlides();
}
代码不是很难,仔细研究一下就能明白原理了。
版权声明
文章来源: https://www.uihtm.com/jquery/8803.html
版权说明:仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。我们非常重视版权问题,如有侵权请邮件(44784009#qq.com)与我们联系处理。敬请谅解!






















