user14337693
user14337693

Reputation: 27

Make button active only when first slide is active - Swiper slider

I need a button to be active only when first slide is active. I tried this code, but it doesn't work properly - button becomes disabled just always. What is wrong?

if ($("#aslide").attr("swiper-slide-active")) {
     //
} else {
    $("#acceptbtn").attr("disabled", "disabled");
}

Upvotes: 0

Views: 3241

Answers (2)

eh8
eh8

Reputation: 46

test

$('#btn_asd2231').attr('disabled', true);

seems to work for me, when I try to disable the button or enable it. Maybe is a bug somewhere else in code.

Upvotes: 1

Ezra Siton
Ezra Siton

Reputation: 7741

One Way:

Use Swiper API event slideChange (Event will be fired when currently active slide is changed) -AND- realIndex (Index number of currently active slide considering duplicated slides in loop mode) . https://swiperjs.com/api/

/* swiper events */
swiper.on("slideChange", function() {
  console.log("slide changed - current slide is: " + this.realIndex )
  if(this.realIndex == 0){
    console.log("first slide do something")
  }
  else{
    console.log("not first slide do somehing")
  }
});

disabled button related Q:

Basic Snippet

var swiper = new Swiper('.swiper-container', {
  navigation: {
    nextEl: '.swiper-button-next',
    prevEl: '.swiper-button-prev',
  },
  scrollbar: {
    el: '.swiper-scrollbar',
    draggable: true,
  }
});

let button = document.getElementById("button")

/* swiper events */
swiper.on("slideChange", function() {
  console.log("slide changed - current slide is: " + this.realIndex )
  if(this.realIndex == 0){
    console.log("first slide do something")
    button.disabled = false;  
  }
  else{
    console.log("not first slide do somehing")
    button.disabled = true;  
  }
});
html,
    body {
      position: relative;
      height: 100%;
    }

    body {
      background: #eee;
      font-size: 14px;
      color: #000;
      margin: 0;
      padding: 0;
    }

    .swiper-container {
      width: 100%;
      height: 100%;
    }

    .swiper-slide {
      text-align: center;
      font-size: 18px;
      background: #fff;
      /* Center slide text vertically */
      display: flex;
      justify-content: center;
      align-items: center;
    }
<link rel="stylesheet" href="https://unpkg.com/swiper/swiper-bundle.min.css">

<button id="button">Button</button>

<!-- Slider main container -->
<div class="swiper-container">
    <!-- Additional required wrapper -->
    <div class="swiper-wrapper">
        <!-- Slides -->
        <div class="swiper-slide">Slide 1</div>
        <div class="swiper-slide">Slide 2</div>
        <div class="swiper-slide">Slide 3</div>
    </div>
    <!-- If we need pagination -->
    <div class="swiper-pagination"></div>

    <!-- If we need navigation buttons -->
    <div class="swiper-button-prev"></div>
    <div class="swiper-button-next"></div>

    <!-- If we need scrollbar -->
    <div class="swiper-scrollbar"></div>
</div>


<script src="https://unpkg.com/swiper/swiper-bundle.min.js"></script>

Upvotes: 0

Related Questions