[英]Supersized random thumb order
我在Supersized中设置了随机的幻灯片顺序,但是只有背景图像是随机的,拇指保持相同的顺序。
这是随机生成图像幻灯片的代码部分(supersized.3.2.7.js):
// Shuffle slide order if needed
if (base.options.random){
arr = base.options.slides;
for(var j, x, i = arr.length; i; j = parseInt(Math.random() * i), x = arr[--i], arr[i] = arr[j], arr[j] = x); // Fisher-Yates shuffle algorithm (jsfromhell.com/array/shuffle)
base.options.slides = arr;
}
这就是我调用幻灯片图像并设置拇指的方式:
jQuery(function($){
$.supersized({
random: 1,
thumb_links: 1,
slides: [
{ image: "slide_1.jpg", thumb: "thumb_1.jpg"},
{ image: "slide_2.jpg", thumb: "thumb_2.jpg"},
{ image: "slide_3.jpg", thumb: "thumb_3.jpg"},
{ image: "slide_4.jpg", thumb: "thumb_4.jpg"},
{ image: "slide_5.jpg", thumb: "thumb_5.jpg"},
{ image: "slide_6.jpg", thumb: "thumb_6.jpg"}
]
});
});
如何使拇指按背景图像的相同随机顺序排列?
我自己弄清楚了:我没有使用Supersized中的random选项,而是定义了一个数组并对它进行排序。
var slidesArray = [
{ image: "slide_1.jpg", thumb: "thumb_1.jpg"},
{ image: "slide_2.jpg", thumb: "thumb_2.jpg"},
{ image: "slide_3.jpg", thumb: "thumb_3.jpg"},
{ image: "slide_4.jpg", thumb: "thumb_4.jpg"},
{ image: "slide_5.jpg", thumb: "thumb_5.jpg"},
{ image: "slide_6.jpg", thumb: "thumb_6.jpg"}
]
我称这个插件为:
$.supersized({
random: 0,
thumb_links: 1,
slides: slidesArray.sort(function() {return 0.5 - Math.random()})
});
效果很好,但是我不确定这是否是最好的方法。 有什么建议么?
考虑到文档中提到random
只影响幻灯片,似乎手动将列表随机化,或者以其他方式将其重新排序为几乎您需要的其他任何方式,确实是最好的方法。
我找到了一种方法,...
var slidesArray = [
{ image: "slide_1.jpg", thumb: "thumb_1.jpg"},
{ image: "slide_2.jpg", thumb: "thumb_2.jpg"},
{ image: "slide_3.jpg", thumb: "thumb_3.jpg"}
]
和…
$.supersized({
random: 0,
thumb_links: 1,
slides: slidesArray.sort(function() {return 0.5 - Math.random()})
});
我是javascript的新手……关于如何使其变得更好的任何想法?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.