video多视频轮播Swiper 播放视频不轮播不循环
在实际工作中经常会遇到swiper轮播多个视频,播放视频不轮播不循环
loop:true下问题:
解决方法:不要在html绑定@click事件监听不到 使用swiper的onclick回调函数即:$(".video").on("click",function(){...}),
on: {
slideChangeTransitionEnd: function(){
console.log(this.activeIndex)
},
},
(3)loop:true下当前选中slide带有class:.swiper-slide-active 做相关操作在这个class下处理
$(".swiper-slide-active video").on('play',function(){
//播放状态
});
$(".swiper-slide-active video").on('pause',function(){
//暂停状态
});
停止自动轮播:_this.swiper1.autoplay.stop();
启动自动轮播:_this.swiper1.autoplay.start();
3、loop:false下问题:
on: {
slideChangeTransitionEnd: function(){
console.log(this.activeIndex)
},
},
不循环loop去掉就行
------------------------------------------------------------------------------------------------------------------------
例:

index.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>3、video多视频swiper播放停止轮播循环loop=true</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" />
<!-- 公用css -->
<link rel="stylesheet" href="css/public/reset.css">
<link rel="stylesheet" href="css/public/common.css">
<link rel="stylesheet" href="css/public/swiper.min.css">
<!-- rem.js -->
<script src="js/must/rem.js"></script>
<style>
.video{position:relative;overflow:hidden;width:60%;height:60%;margin:10% auto 0 auto}
.video-cover{position:absolute;z-index:10;width:100%;height:100%;top:0;left:0;background:rgba(0,0,0,0.3)}
img{display:block;width:100%}
.video-cover .play-ico{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}
</style>
</head>
<body>
<div id="app" v-cloak>
<!-- 页面进入视频倒计时播放 -->
<div class="video">
<div class="swiper-container">
<div class="swiper-wrapper" style='height:auto'>
<div class="swiper-slide" style='height:100%' v-for='item,index in videoData'>
<div class="video-cover">
<img class="play-ico" style="width: .5rem;" src="data:images/play.png" alt="">
<img class="videoImg":src="item.image_cover" alt="" >
</div> <div class="video-box" :class = "'dialog'+index">
<video :id="'video'+index" type="video/mp4" :src="item.videoPlay" controls="controls" class="videos" style='width:100%;'></video>
</div>
</div>
</div>
<div class="swiper-pagination" style ="width: 20%;transform: translateX(-50%);left: 50%;height: 34px;"></div>
</div>
</div>
</div>
<!-- 公用js -->
<script src="js/must/vue.js"></script>
<script src="js/must/swiper.min.js"></script>
<script src="js/must/jquery_1.12.3_jquery.min.js"></script>
<script src="js/index.js"></script>
</body>
</html>
index.js
var vm = new Vue({
el:'#app',
data:{
// 视频data
videoData:[
{
image_cover: "http://mall.faw-vw.com/shop-m/page/activity/2020-0606/images/playImg1.png",
videoPlay: "http://mall.faw-vw.com/shop-m/page/activity/2020-0606/images/video1.mp4",
},
{
image_cover: "http://mall.faw-vw.com/shop-m/page/activity/2020-0606/images/playImg2.jpg",
videoPlay: "http://mall.faw-vw.com/shop-m/page/activity/2020-0606/images/video2.mp4",
}
],
swiper1:''
},
created(){
},
mounted: function () {
var _this = this;
_this.swiper1 = new Swiper('.swiper-container',{
observer: true, //解决刷新不能滑动问题
observeParents: true, //解决刷新不能滑动问题
observeSlideChildren:true,
slidesPerView: 'auto',
autoHeight: true,
initialSlide: 0,
loop: true,
autoplay: true,
on: {
// 监听轮播:loop: true时this.activeIndex不在是数据索引,而是复制多个的slide个数值,
// loop去掉时 this.activeIndex是数据索引,slide个数是数据length
slideChangeTransitionEnd: function(){
console.log(this.activeIndex)
// 轮播时所有视频停止播放, 封面图显示,视频隐藏
var videoLength=$(".videos").length;
for(var i=0; i<videoLength; i++){
$(".videos").eq(i)[0].pause();
}
$(".video-cover,.videoImg").show();
$(".video-box").hide();
},
},
pagination: {
el: '.swiper-pagination',
clickable: true,
},
});
// 视频播放事件创建 loop为true时会复制多个slide,无法监听元素索引值,不要在html上@click,要绑定class用js实现
$(".video-cover").on("click",function(){
_this.playVideo();
})
},
methods:{
playVideo: function () {
var _this = this;
_this.swiper1.autoplay.stop();
$(".swiper-slide-active .video-cover,.swiper-slide-active .videoImg").hide();
$(".swiper-slide-active .video-box").show();
// 点击哪个视频哪个播放
$(".swiper-slide-active .video-box .videos")[0].play();
//监听当前视频播放状态
$(".swiper-slide-active .video-box .videos").on('play',function(){
_this.swiper1.autoplay.stop()
});
$(".swiper-slide-active .video-box .videos").on('pause',function(){
_this.swiper1.autoplay.start()
});
},
},
})
video多视频轮播Swiper 播放视频不轮播不循环的更多相关文章
- 群晖synology的Video Station无法通过浏览器在线播放视频
群晖synology的Video Station无法通过浏览器在线播放视频 http://www.hangge.com/blog/cache/detail_419.html
- 手机浏览器自动播放视频video(设置autoplay无效)的解决方案
1.问题的提出 某一天接了个需求,需要在手机的H5页面内加入视频,我开开心心做完,准备交付的时候,问题来了,PM想要用户一进入页面,视频就开始播放,不需要用户手动点击. 2.尝试解决 加autopla ...
- video播放视频以及相关事件
<!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Conten ...
- 使用VideoView播放视频
为了在Android应用中播放视频,Android提供了VideoView组件,它就是一个位于android.widget包下的组件,它的作用与ImageView类似,只是ImageView用于显示图 ...
- android: 播放视频
播放视频文件其实并不比播放音频文件复杂,主要是使用 VideoView 类来实现的.这个 类将视频的显示和控制集于一身,使得我们仅仅借助它就可以完成一个简易的视频播放器. VideoView 的用法和 ...
- Android 视频播放器 (一):使用VideoView播放视频
一.简介 作为Android开发,我们不可避免的会接触到视频播放,VideoView做为最简单的播放器,我们是不应该不会的. 下面简单介绍一下VideoView: VideoView是使用MediaP ...
- Android开发之使用VideoView播放视频
Android提供了 VideoView组件.它的作用与ImageView类似,仅仅是ImageView用于显示图片.而VideoView用于播放视频. 使用VideoView播放视频的过程例如以下: ...
- iOS视频边下边播--缓存播放数据流
实现视频边下边播,这里的边下边播不是单独开一个子线程去下载,而是把视频播放的数据给保存到本地.简而言之,就是使用一遍的流量,既播放了视频,也保存了视频. 用到的框架:<AVFoundation/ ...
- HTML5 video标签播放视频下载原理
HTML5 video https://github.com/remy/html5demos/blob/master/demos/video.html <video preload=" ...
- 解决html5 video不能播放 能播放声音不能播放视频
<video id="playVideo" style="width:90%; height:auto;" controls poster=". ...
随机推荐
- 【每日一题】【map操作】【滑动窗口所需元素】2021年12月22日-76. 最小覆盖子串
给你一个字符串 s .一个字符串 t .返回 s 中涵盖 t 所有字符的最小子串.如果 s 中不存在涵盖 t 所有字符的子串,则返回空字符串 "" . 注意: 对于 t 中重复字符 ...
- 【大数据面试】【项目开发经验】Hadoop、Flume、Kafka、Hive、MySQL、Sqoop、Azkaban、Spark
主要内容:框架层面的调优.业务经验 一.Hadoop 1.Hadoop基准测试(HDFS的读写性能.MapReduce的计算能力测试) (1)测试内容:文件上传下载的时间 (2)服务器有几个硬盘插槽 ...
- pycharm 小技巧
ctrl键 + B 查看定义源代码 alt键 + enter键 查看帮助 ctrl键 + shift键 + -号 所有代码隐藏 ctrl键 + shift键 + +号 所有代码展示 ctrl键 + D ...
- ArcObjects SDK开发 017 在ArcObject SDK 中使用Toolbox
1.Geoprocessor和IGPProcess Geoprocessor是ArcObjects SDK中定义Tool执行器.IGPProcess接口是ArcObjects SDK中定义的ArcTo ...
- 如何在 .Net 7 中将 Query 绑定到数组
在 .Net 7 中,我们可以通过绑定数组的方式来接收来自查询字符串的参数.这样就不需要再使用逗号分隔的字符串来获取参数了. 代码演示 假设我们需要从 query 上接受多个 id 并返回查询的结果. ...
- Wireshark网卡无法找到或没有显示的问题
问题背景 最近在处理公司内网域名解析的问题,发现配置好一个新域名在内网环境可以正常解析成内网IP,但使用深信服VPN却无法正常解析,并且其他域名使用深信服VPN可以正常解析,所以参考<内网域名解 ...
- [C#]C++/CLI中interior_ptr和pin_ptr的区别
interior_ptr 当垃圾回收器移动对象时,Interior pointer能随之移动,并始终指向该对象. 但是如果把这个指针返回给外部函数,那么当垃圾回收时(垃圾回收期间会压缩对象,),对象地 ...
- [Leetcode]扁平化多级双向链表
题目 https://leetcode-cn.com/explore/learn/card/linked-list/197/conclusion/764/ 代码 /* // Definition ...
- lock 和 Monitor (转载)
Lock和Monitor都是对被操作对象同步控制的方法 Lock 是 Monitor的简化版本,IL callvirt ...Monitor.Enter(object)...leave.s.... c ...
- 动力节点——day02
ipconfig ip地址的配置信息,ipconfig -all 更详细的配置信息 查看两台计算机是否可以正常通信 ping ip地址/域名(-t) 快捷键:ctrl+c复制 ctrl+v粘贴 c ...