RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1144393
Accepted
HamSter
HamSter
Asked:2020-06-23 01:00:20 +0000 UTC2020-06-23 01:00:20 +0000 UTC 2020-06-23 01:00:20 +0000 UTC

带有视频和自动播放的进度光滑滑块点

  • 772

有一个带有自动播放和视频的光滑滑块:

if ($('.slider').length) {
  $('.slider').each(function() {

    var $this = $(this);


    $this.on('init', function(event) {
      $(".video").each(function(i, e) {
        e.play();
      });
    });

    $this.slick({
      slidesToShow: 1,
      slidesToScroll: 1,
      dots: true,
      infinite: true,
      autoplay: true,
      autoplaySpeed: 3000
    });




    function reloadBGVid() {
      $(".video").each(function(i, e) {
        if (e.paused) e.play();
      });
    }

  });
}
.slider,
.item {
  height: 20rem;
}

.item img {
  max-width: 100%;
}

.slick-dots {
  display: flex;
  justify-content: center;
  list-style-type: none;
  padding: 0;
  margin: 0;
  font-size: 0;
  line-height: 0;
  position: absolute;
  bottom: 1rem;
  left: 4rem;
}

.slick-dots li {
  width: 1.75rem;
  height: 1.75rem;
  opacity: 1;
  background-color: transparent;
  border: 1px solid #000;
  padding: 0px;
  font-size: 0px;
  line-height: 0px;
  cursor: pointer;
  position: relative;
  margin: 0 5px;
  opacity: .8;
  -webkit-transition: all .2s ease-in-out;
  -o-transition: all .2s ease-in-out;
  transition: all .2s ease-in-out;
}

.slick-dots li button {
  font-size: 0px;
  line-height: 0px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 0px;
  padding: 0;
  margin: 0;
  border: none;
  background: red;
}

.slider .slick-dots li:hover,
.slider .slick-dots li.slick-active {
  background-color: #a08a7f;
}

.slider .slick-dots li.slick-active~li {
  background-size: 0% 0%;
}


/* .slider .slick-dots li.slick-active{
  -webkit-animation:right 3s ease-in-out forwards;
  -moz-animation:right 3s ease-in-out forwards;
  -o-animation:right 3s ease-in-out forwards;
  animation:right 3s ease-in-out forwards;
}

@keyframes right{
  0%{
    background-size:0% 100%;
  }

  100%{
    background-size:100% 100%;
  }
} */

.slider .slick-dots li.slick-active button {
  -webkit-animation: rightB 3s ease-in-out forwards;
  -moz-animation: rightB 3s ease-in-out forwards;
  -o-animation: rightB 3s ease-in-out forwards;
  animation: rightB 3s ease-in-out forwards;
}

@keyframes rightB {
  0% {
    width: 0%;
  }
  100% {
    width: 100%;
  }
}
<script src="https://code.jquery.com/jquery-3.0.0.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.9.0/slick.min.css" integrity="sha256-UK1EiopXIL+KVhfbFa8xrmAWPeBjMVdvYMYkTAEv/HI=" crossorigin="anonymous" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.9.0/slick.min.js" integrity="sha256-NXRS8qVcmZ3dOv3LziwznUHPegFhPZ1F/4inU7uC8h0=" crossorigin="anonymous"></script>

<div class="slider">
  <div class="item">
    <video class="video" muted loop preload>
        <source src="https://www.w3schools.com/html/mov_bbb.mp4" type="video/mp4">
        <source src="https://www.w3schools.com/html/mov_bbb.ogg" type="video/ogg">
          
      </video>
  </div>
  <div class="item">
    <img src="https://encrypted-tbn0.gstatic.com/images?q=tbn%3AANd9GcQu4CgFeghuoip9xGUET9Ebm4SHUoEHb35dVx1gtVv_Vrfv1i-5&usqp=CAU" alt="">
  </div>
  <div class="item">
    <img src="https://isstatic.askoverflow.dev/NoaWt.jpg" alt="">
  </div>
</div>

实现了点切换的进展。

问题:如何在考虑到视频的情况下实现光滑滑块的自动播放(即,当切换到带有视频的幻灯片时 - 幻灯片播放不是 3 秒,而是直到视频结束)和点上的进度?

jquery
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Grundy
    2020-06-24T04:08:23Z2020-06-24T04:08:23Z

    看起来没有内置的自动播放时间自动更改,但您可以模拟它。

    为此,您需要:

    1. 检查当前幻灯片上是否有视频
    2. 如果不是,将标准间隔设置为 3 秒
    3. 如果有
      1. 停止自动播放
      2. 获取视频时长
      3. 设置动画持续时间
      4. 开始自动播放
      5. 开始视频

    您可以使用duration 属性来获取视频的持续时间。但是,它可能未填写,在这种情况下,您可以订阅loadmetadata 事件并在处理程序中使用此属性。

    实现示例:

    function defaultAutoplay(slick) {
      slick.options.autoplaySpeed = 3 * 1000;
      slick.play();
    }
    
    function videoAutoplay(slick, index, videoDuration, inited) {
      slick.options.autoplaySpeed = videoDuration * 1000;
      slick.play();
      if (!inited) {
        slick.$dots.find(`li:nth-child(${index+1}) button`)
          .css('animation-duration', `${videoDuration}s`)
          .addClass('inited-video');
      }
    }
    
    function processVideo(slick, index, video, inited) {
      slick.pause();
    
      if (isFinite(video.duration)) {
        video.play();
        return videoAutoplay(slick, index, video.duration, inited);
      }
    
      video.addEventListener('loadedmetadata', function() {
        videoAutoplay(slick, index, video.duration, inited);
      });
      video.play();
    }
    
    if ($('.slider').length) {
      $('.slider').each(function() {
    
        var $this = $(this);
        $this.on('init', function(event, slick) {
          var video = slick.$slides[slick.currentSlide].querySelector('video');
          if (!video) {
            return defaultAutoplay(slick);
          }
    
          processVideo(slick, slick.currentSlide, video);
    
        });
    
        $this.on('beforeChange', function(e, slick, currentSlide, nextSlide) {
          var video = slick.$slides[nextSlide].querySelector('video');
          if (!video) {
            return defaultAutoplay(slick);
          }
    
          var inited = slick.$dots.find(`li:nth-child(${nextSlide+1}) button`)
            .hasClass('inited-video');
          processVideo(slick, nextSlide, video, inited);
        });
    
        $this.slick({
          slidesToShow: 1,
          slidesToScroll: 1,
          dots: true,
          infinite: true,
          autoplay: true,
          autoplaySpeed: 3000
        });
      });
    }
    .slider,
    .item {
      height: 20rem;
    }
    
    .item img {
      max-width: 100%;
    }
    
    .slick-dots {
      display: flex;
      justify-content: center;
      list-style-type: none;
      padding: 0;
      margin: 0;
      font-size: 0;
      line-height: 0;
      position: absolute;
      bottom: 1rem;
      left: 4rem;
    }
    
    .slick-dots li {
      width: 1.75rem;
      height: 1.75rem;
      opacity: 1;
      background-color: transparent;
      border: 1px solid #000;
      padding: 0px;
      font-size: 0px;
      line-height: 0px;
      cursor: pointer;
      position: relative;
      margin: 0 5px;
      opacity: .8;
      -webkit-transition: all .2s ease-in-out;
      -o-transition: all .2s ease-in-out;
      transition: all .2s ease-in-out;
    }
    
    .slick-dots li button {
      font-size: 0px;
      line-height: 0px;
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      width: 0px;
      padding: 0;
      margin: 0;
      border: none;
      background: red;
    }
    
    .slider .slick-dots li:hover,
    .slider .slick-dots li.slick-active {
      background-color: #a08a7f;
    }
    
    .slider .slick-dots li.slick-active~li {
      background-size: 0% 0%;
    }
    
    
    /* .slider .slick-dots li.slick-active{
      -webkit-animation:right 3s ease-in-out forwards;
      -moz-animation:right 3s ease-in-out forwards;
      -o-animation:right 3s ease-in-out forwards;
      animation:right 3s ease-in-out forwards;
    }
    
    @keyframes right{
      0%{
        background-size:0% 100%;
      }
    
      100%{
        background-size:100% 100%;
      }
    } */
    
    .slider .slick-dots li.slick-active button {
      -webkit-animation: rightB 3s ease-in-out forwards;
      -moz-animation: rightB 3s ease-in-out forwards;
      -o-animation: rightB 3s ease-in-out forwards;
      animation: rightB 3s ease-in-out forwards;
    }
    
    @keyframes rightB {
      0% {
        width: 0%;
      }
      100% {
        width: 100%;
      }
    }
    <script src="https://code.jquery.com/jquery-3.0.0.js"></script>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.9.0/slick.min.css" integrity="sha256-UK1EiopXIL+KVhfbFa8xrmAWPeBjMVdvYMYkTAEv/HI=" crossorigin="anonymous" />
    <script src="https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.9.0/slick.js" crossorigin="anonymous"></script>
    
    <div class="slider">
      <div class="item">
        <video class="video" muted preload>
            <source src="https://www.w3schools.com/html/mov_bbb.mp4" type="video/mp4">
            <source src="https://www.w3schools.com/html/mov_bbb.ogg" type="video/ogg">
              
          </video>
      </div>
      <div class="item">
        <img src="https://encrypted-tbn0.gstatic.com/images?q=tbn%3AANd9GcQu4CgFeghuoip9xGUET9Ebm4SHUoEHb35dVx1gtVv_Vrfv1i-5&usqp=CAU" alt="">
      </div>
      <div class="item">
        <video class="video" muted preload>
            <source src="https://www.w3schools.com/html/mov_bbb.mp4" type="video/mp4">
            <source src="https://www.w3schools.com/html/mov_bbb.ogg" type="video/ogg">
              
          </video>
      </div>
      <div class="item">
        <img src="https://isstatic.askoverflow.dev/NoaWt.jpg" alt="">
      </div>
    </div>

    • 1

相关问题

  • jquery轨道输入点击

  • 滑块光滑 nextSlider + 1

  • jquery选择器+获取值

  • JQ Masked Input电话号码填写时如何避免输入数字7和8?

  • 如何获取相邻父级 jQuery 的元素?

  • 如何解析收到的json响应

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5