- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我想知道使用 JavaScript/jQuery 为网站构建 Infinity-Image-Loop-Slider 的最佳(良好可读代码、有害实践代码、可重用性)概念是什么?我不知道如何编写幻灯片放映代码,但什么蓝图符合上述要求。 我的问题的主要焦点是如何排列图片以获得无限循环 slider 的印象。
通过查看来自不同 slider 的代码,我发现了两种解决方案:
-每次显示下一张/上一张图像时更改所有图像的 z-Index。
- 更改图像在 DOM 中的位置。
但是检查和理解别人的代码是非常耗时的——这就是我问这个问题的原因:-)
最佳答案
tl;dr - JSBin 示例:http://jsbin.com/ufoceq/8/
无需太多努力即可创建无限图像 slider 的简单方法如下:为简单起见,假设您有 <n>
图像循环滑动,以便在 n
之后th 下一个要可视化的图像是 1
st(反之亦然)。
我们的想法是创建第一张和最后一张图像的克隆
无论您的图片有多少,您最多只需要附加 2 个克隆元素。
再次为简单起见,假设所有图像都是 100px
宽,它们被包裹在一个容器中,您可以使用 overflow: hidden
向左/向右移动到一个剪裁的面具中.然后,所有图像都可以很容易地排成一行 display: inline-block
和 white-space: nowrap
在容器上设置(使用 flexbox
现在更容易)。
对于 n = 4
DOM 结构将是这样的:
offset(px) 0 100 200 300 400 500
images | 4c | 1 | 2 | 3 | 4 | 1c
/* ^^ ^^
[ Clone of the last image ] [ Clone of the 1st image ]
*/
一开始,你的容器会定位在left: -100px
(或者也是 margin-left: -100px
or even better (for a matter of performance) transform: translateX(-100px)
),所以 slider 可以显示第一张图片。要从一个图像切换到另一个图像,您需要在您之前选择的同一属性上应用 javascript 动画。
当您的 slider 当前位于第 4 个th 图像时,您必须从图像 4
切换至 1c
,所以我们的想法是在动画结束时执行回调,很快将您的 slider 包装器重新定位在真正的 1st 图像偏移处(例如,您将 left: -100px
设置为容器)
这类似于当您的 slider 当前位于第一个st 元素上时:要显示上一张图像,您只需要从图像 1
执行动画。至 4c
当动画完成后,您只需移动容器,使 slider 立即定位在第 4 个 图像偏移处(例如,您将 left: -400px
设置为容器)。
您可以在上面的 fiddle 上看到效果:这是最小的 js/jquery
我使用的代码(当然代码甚至可以优化,因此元素的宽度不会硬编码到脚本中)
$(function() {
var gallery = $('#gallery ul'),
items = gallery.find('li'),
len = items.length,
current = 1, /* the item we're currently looking */
first = items.filter(':first'),
last = items.filter(':last'),
triggers = $('button');
/* 1. Cloning first and last item */
first.before(last.clone(true));
last.after(first.clone(true));
/* 2. Set button handlers */
triggers.on('click', function() {
var cycle, delta;
if (gallery.is(':not(:animated)')) {
cycle = false;
delta = (this.id === "prev")? -1 : 1;
/* in the example buttons have id "prev" or "next" */
gallery.animate({ left: "+=" + (-100 * delta) }, function() {
current += delta;
/**
* we're cycling the slider when the the value of "current"
* variable (after increment/decrement) is 0 or when it exceeds
* the initial gallery length
*/
cycle = (current === 0 || current > len);
if (cycle) {
/* we switched from image 1 to 4-cloned or
from image 4 to 1-cloned */
current = (current === 0)? len : 1;
gallery.css({left: -100 * current });
}
});
}
});
});
如前所述,这个解决方案并不需要太多的努力和谈论性能,将这种方法与没有循环的普通 slider 进行比较,它只需要在 slider 初始化时进行两次额外的 DOM 插入和一些(非常简单) 管理后向/前向循环的额外逻辑。
这是您同时看到两个元素的另一个示例:在这种情况下,您需要克隆更多元素并对逻辑进行一些简单的更改
https://codepen.io/fcalderan/pen/bGbjZdz
我不知道是否存在更简单或更好的方法,但无论如何希望这对您有所帮助。
注意:如果您还需要有一个响应式画廊,也许this answer也可能有帮助
关于javascript - 无限循环 slider 概念,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15876754/
我正在尝试使用 div 和 javascript 创建一个简单的 slider 。我设置了一个包含六个图像的 div 和一个箭头,每次单击它时,该箭头都会将包含图像的容器拍摄为 528px(每个图像的
我使用flexslider,当我按照他们网站上的说明操作时,它不适用于多个 slider ,这是代码: 我需要在两个 slider 上都有一个 Controller 导航,说明如下: http://w
这是一个困难的问题,我一直在努力让它发挥作用。它确实起作用了一半,但我认为逻辑是问题所在。下面我会解释一下情况和问题。 情况:想要使用 slider Controller 来选择房间内可以占用的成人、
我制作了一个简单的 slider ,它适用于普通表格,但是当我尝试将该 slider 用于我的自定义 Bootstrap 表格时,只有第一个、第三个 slider 出现,而不是第二个和第四个。 var
我正在使用 Bootstrap slider http://seiyria.com/bootstrap-slider/对于贷款产生者。这里没问题。 但是我必须使用相同的 slider ,一个位于顶部,
我正在使用光滑的 slider 。我在页面上有三个 slider ,它们都有相同的类和光滑的选项。但是,我想要三个不同的灵活“autoplaySpeed”选项,或者为所有三个 slider 分别添加随
我试图用 Slider2 和 Slider3 的总和来更新 Slider1 的值,但它只显示 Slider1 或 Slider2 的值,以移动的为准。我在更新 Slider1 的值时犯了一些错误。 H
我使用 css 和 html 以及 jQuery 创建了一个 slider 。该 slider 与下一个按钮配合使用效果很好,但与上一个按钮配合使用效果不佳。 假设我在第一张幻灯片上有五个元素,总共有
我正在制作一个包含多个 slider 的页面,其中 slider 的数量和选项根据用户的不同而不同。我遇到一个问题,所有 slider 都已创建并显示,但只有最后一个 slider 是可拖动的。 简单
我正在尝试获取 jQuery-UI slider 的当前值在 JavaScript 函数中,它不起作用。如果我这样做 $("#someParticularDOMObject").find(".sl
我正在尝试在 JQuery UI 中的 slider 的 slide 和 change 事件上同时更新多个 slider 。 我有如下代码: $(function() { var totalS
我正在使用来自 Filament 组的 jQuery UI slider ,它将 SELECT 元素转换为 slider 。它工作正常。现在我想使用 JavaScript 以编程方式将 slider
是否可以在 NIVO SLIDER 中将幻灯片设为链接? 最佳答案 嗯,不知道是不是一样,但是...... 我在 IE 所有版本中的链接都有问题,其他浏览器工作正常,通过添加解决: backgroun
在我的项目中,我使用了光滑的 slider 插件(http://kenwheeler.github.io/slick/) 我需要更改单词的默认点导航。单击单词后应更改幻灯片。 最佳答案 这是更新的代码
我正在使用 nivo slider (默认主题),我将上一个和下一个箭头定位在图像旁边(不是在图像顶部),我想知道是否有一种方法可以始终显示下一个和上一个箭头(现在箭头仅在您将鼠标悬停在图像上时显示)
我正在使用 Slider在我的 javaFX 项目中,我有一个 Label当我移动 slider 时会更新。 我想要 Label在我拖动 Slider 时进行更新不仅在拖放时。 这是我的代码: be
我有一个事件站点,一页上有 3 个光滑的 slider ,通常光滑的 slider 不会初始化,而是我只看到所有的图像,有时如果我刷新它们都开始工作。 https://au.hairandme.com
我想让每年一定数量的海龟(由 slider 控制)死亡。到目前为止,我明白了,它可能非常简单,但我似乎无法使其发挥作用。多谢! to hunting let huntedturtles (count
我有一个带背景图像的全宽 slider 。 slider 高度根据图像进行响应,因此它始终在屏幕的一侧到另一侧显示 100% 的图像。 现在我尝试将内容(文本)放置在 slider 内,使其位于内容网
我对 Swiper slider 有一些问题。当我滚动到 slider 的末尾时,可以看到一些空白区域。 http://take.ms/siqXj swiper = new Swiper(profil
我是一名优秀的程序员,十分优秀!