【问题标题】:Make button active only when first slide is active - Swiper slider仅在第一张幻灯片处于活动状态时才使按钮处于活动状态 - Swiper 滑块
【发布时间】:2020-11-29 05:54:24
【问题描述】:

我需要一个按钮,只有在第一张幻灯片处于活动状态时才处于活动状态。我试过这段代码,但它不能正常工作 - 按钮总是被禁用。怎么了?

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

【问题讨论】:

    标签: javascript html slider swiper


    【解决方案1】:

    测试

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

    当我尝试禁用或启用按钮时,似乎对我有用。也许是代码中其他地方的错误。

    【讨论】:

      【解决方案2】:

      一种方式:

      使用 Swiper API 事件 slideChange(当前活动幻灯片更改时将触发事件)-AND- realIndex当前活动幻灯片的索引号考虑以循环模式复制幻灯片)。 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按钮相关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>

      【讨论】:

      • 谢谢!我以前试过这个,但没有成功。意识到我有一个旧版本的 Swiper。现在可以了!
      猜你喜欢
      • 1970-01-01
      • 2021-10-10
      • 1970-01-01
      • 2019-07-09
      • 2020-03-04
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多