• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
天微凉321
博客园    首页    新随笔    联系   管理    订阅  订阅

swiper中有视频时,滑动停止后视频停止播放

我们可以用swiper实现这个功能。用法就跟放图片一样,只是这里把图片换成视频就可以了。

只是如果放的是视频的话,就有一个问题,就是我们怎么在滑动结束的时候,自动停止播放上一个视频呢?

我们可以利用 swiper 提供的 onSlideChangeEnd (注意swiper 版本,我用的是swiper 3)方法来做到这种效果,具体代码如下:

$(".swiper-container").each(function () { //写each是用于一个页面出现多个轮播
        var _this = $(this);
        var videoList = $(this).find("video"); //找到轮播图下面的视频个数
        var space = $(this).data("space");
        var count = $(this).data("count") || 1;
        var swiperSetting = {};
        swiperSetting.pagination = ".swiper-pagination";
        swiperSetting.preloadImages = false;
        swiperSetting.lazyLoading = true;
        swiperSetting.loop = true;
        swiperSetting.spaceBetween = space;
        swiperSetting.slidesPerView = count;
        if (videoList.length) { 
            swiperSetting.autoplay = false; //如果有视频,禁止循环播放
            swiperSetting.onSlideChangeEnd = function (swiper) { //滚动停止后视频停止播放
                for (var i = 0; i < videoList.length; i++) {
                    videoList[i].pause();
                }
            }
        } else {
            swiperSetting.autoplay = 3000; //没视频时,每隔3秒播放
        }
        new Swiper(_this, swiperSetting); 
    });
posted @ 2019-08-06 14:09  天微亮~敏  阅读(2792)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3