Reputation: 27
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
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
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:
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