Randomise Bootstrap Carousel Slides除了第一张幻灯片

时间:2016-02-16 15:20:38

标签: javascript jquery html css twitter-bootstrap

我有一个带有5张幻灯片的自举旋转木马,想要将它们随机化,但始终保持同一张幻灯片。

因此它可以加载并成为这些订单中的任何一个。

1 3 2 5 4 // 1 2 5 4 3 // 1 5 2 4 3

我可以使用带有数学底线的javascript但这适用于所有这些而不仅仅是幻灯片2,3,4,5

有没有这样做的方法?它显然不需要是bootstrap本地的。每个幻灯片都是<div>元素,而不是<li>,我使用数据属性而不是javascript来初始化滑块,如果需要,我可以更改它。

传送带:

<div id="carousel-example-generic" class="carousel slide" data-ride="carousel" data-interval="5000" data-pause="hover">

 <!-- Indicators -->
  <ol class="carousel-indicators hidden-xs hidden-sm">
    <li data-target="#carousel-example-generic" data-slide-to="0" class="active"></li>
    <li data-target="#carousel-example-generic" data-slide-to="1"></li>
    <li data-target="#carousel-example-generic" data-slide-to="2"></li>
    <li data-target="#carousel-example-generic" data-slide-to="3"></li>
    <li data-target="#carousel-example-generic" data-slide-to="4"></li>
  </ol>

  <!-- Wrapper for slides -->
   <div class="carousel-inner left-bottom-corner right-bottom-corner" role="listbox">
    <div class="item active">
      <img class="hidden-xs" src="<?php the_field('home_slide_home'); ?>" alt="...">
      <img class="visible-xs" src="<?php the_field('home_slide_home_mobile'); ?>" alt="...">
      <div class="carousel-caption">
        <img style="margin-left:auto;margin-right:auto;" src="<?php the_field('home_slide_icon'); ?>" alt="...">
        <?php the_field('slide_home_text'); ?>
        </div>
    </div>

    <div class="item randomslide">
            <img class="hidden-xs" src="<?php the_field('home_slide_1'); ?>" alt="...">
            <img class="visible-xs" src="<?php the_field('home_slide_1_mobile'); ?>" alt="...">
      <div class="carousel-caption">
        <img style="margin-left:auto;margin-right:auto;" src="<?php the_field('home_slide_icon'); ?>" alt="...">
         <?php the_field('slide_1_text'); ?>
         </div></div>

  <div class="item randomslide">
      <img class="hidden-xs" src="<?php the_field('home_slide_2'); ?>" alt="...">
      <img class="visible-xs" src="<?php the_field('home_slide_2_mobile'); ?>" alt="...">
      <div class="carousel-caption">
        <img style="margin-left:auto;margin-right:auto;" src="<?php the_field('home_slide_icon'); ?>" alt="...">
         <?php the_field('slide_2_text'); ?>
         </div>
         </div>

        <div class="item randomslide">
         <img class="hidden-xs" src="<?php the_field('home_slide_3'); ?>" alt="...">
         <img class="visible-xs" src="<?php the_field('home_slide_3_mobile'); ?>" alt="...">
      <div class="carousel-caption">
        <img style="margin-left:auto;margin-right:auto;" src="<?php the_field('home_slide_icon'); ?>" alt="...">
         <?php the_field('slide_3_text'); ?>

         </div>
    </div>

    <div class="item randomslide">
      <img class="hidden-xs" src="<?php the_field('home_slide_4'); ?>" alt="...">
      <img class="visible-xs" src="<?php the_field('home_slide_4_mobile'); ?>" alt="...">
      <div class="carousel-caption">
        <img style="margin-left:auto;margin-right:auto;" src="<?php the_field('home_slide_icon'); ?>" alt="...">
         <?php the_field('slide_4_text'); ?>
         </div> 
    </div>


    </div>
  </div>

我通过@CBroe

的提示进行了管理

下面选择所有滑块,除了第一个具有预定义活动类的滑块,然后将它们混洗。

jQuery(function ($) {
    var parent = $(".carousel-inner");
    var divs = $(".item").not(".item.active");
    while (divs.length) {
        parent.append(divs.splice(Math.floor(Math.random() * divs.length), 1)[0]);
    }
});

2 个答案:

答案 0 :(得分:0)

我通过@CBroe

的提示进行了管理

下面选择所有滑块,除了第一个具有预定义活动类的滑块,然后将它们混洗。

jQuery(function ($) {
    var parent = $(".carousel-inner");
    var divs = $(".item").not(".item.active");
    while (divs.length) {
        parent.append(divs.splice(Math.floor(Math.random() * divs.length), 1)[0]);
    }
});

答案 1 :(得分:0)

您可以使用相关元素创建一个jQuery对象。

var $carouselLi = $('.carousel > ol > li').slice(1);

带有允许数字的数组。

var numbers = [1,2,3,4];

然后遍历$carouselLi并将array中的一个数字设置为元素data-slide-to属性(应确定幻灯片中的位置)。

$.each($carouselLi, function ( key, value ) {
    var index = Math.floor(Math.random() * numbers.length);
    this.dataset.slideTo = numbers[index];
    numbers.splice(index,1);
});

我不确定bootstrap plugin是如何运作的。我假设在分配data-slide-to属性之前不应对其进行初始化。