小鱼儿心语:愿你成为自己的太阳,无须凭借谁的光^ w ^
直接给大家展示下最终效果:可以左右自动滑动,左右箭头可以根据自身需求放开注释的代码即可

AI视频监控.png
轮播图应用页面:
<template>
<div id="home">
<v-carousel
:slideData="slideData"
:height="140"
:begin="0"
:interval="3000"
:dot="true"
:arrow="true"
></v-carousel>
</div>
</template>
<script>
import carousel from "@/components/carousel";
export default {
name: 'home',
components: {
"v-carousel": carousel
},
data() {
return {
slideData: [
{
title: "这是一个Vue轮播图组件",
url: "#",
videos: [
{ video: require("../assets/images/1.mp4") },
{ video: require("../assets/images/2.mp4") }
]
},
{
title: "这是一个Vue轮播图组件",
url: "#",
videos: [
{ video: require("../assets/images/2.mp4") },
{ video: require("../assets/images/3.mp4") }
]
},
{
title: "这是一个Vue轮播图组件",
url: "#",
videos: [
{ video: require("../assets/images/3.mp4") },
{ video: require("../assets/images/4.mp4") }
]
},
{
title: "这是一个Vue轮播图组件",
url: "#",
videos: [
{ video: require("../assets/images/1.mp4") },
{ video: require("../assets/images/4.mp4") }
]
},
{
title: "这是一个Vue轮播图组件",
url: "#",
videos: [
{ video: require("../assets/images/3.mp4") },
{ video: require("../assets/images/1.mp4") }
]
}
],
}
},
methods: {
},
mounted() {
}
}
</script>
<style scoped>
</style>
轮播图组件页面 src\components\carousel.vue
<template>
<div id="carousel">
<div
class="carousel"
ref="carousel"
v-bind:style="{ height: height + 'px' }"
>
<transition-group tag="ul" class="slide clearfix" :name="transitionName">
<li
v-for="(item, index) in slideData"
:key="index"
v-show="index == beginValue"
v-bind:style="{ height: height + 'px' }"
style="display:flex;"
>
<!-- 播放视频 -->
<div v-for="(v, e) in item.videos" :key="e" class="videos">
<video
ref="videoPlay"
muted=""
:src="v.video"
controls="controls"
:autoplay="autoplay"
loop="loop"
style="width:100%;height:100%"
></video>
</div>
</li>
</transition-group>
</div>
</div>
</template>
<script>
import "videojs-contrib-hls";
export default {
name: "carousel",
data() {
return {
setInterval: "",
beginValue: 0,
transitionName: "slide",
mytime_02: true
};
},
beforeDestroy() {
// 组件销毁前,清除监听器
clearInterval(this.setInterval);
},
methods: {
timeupdate(e) {
if (!this.mytime_02) {
return;
} //首次进入能执行
this.mytime_02 = false;
setTimeout(() => {
console.log(parseInt(e.target.currentTime), "event");
this.mytime_02 = true; //上次执行成功,下一次才可执行。
}, 3000);
},
change(key) {
if (key > this.slideData.length - 1) {
key = 0;
}
if (key < 0) {
key = this.slideData.length - 1;
}
this.beginValue = key;
},
autoPlay() {
console.log(this.$refs.carousel.getBoundingClientRect().width);
this.transitionName = "slide";
this.beginValue++;
if (this.beginValue >= this.slideData.length) {
this.beginValue = 0;
return;
}
},
play() {
this.setInterval = setInterval(this.autoPlay, this.interval);
},
mouseOver() {
//鼠标进入
//console.log('over')
clearInterval(this.setInterval);
},
mouseOut() {
//鼠标离开
//console.log('out')
this.play();
},
up() {
//上一页
--this.beginValue;
this.transitionName = "slideBack";
this.change(this.beginValue);
},
next() {
//下一页
++this.beginValue;
this.transitionName = "slide";
this.change(this.beginValue);
}
},
mounted() {
var box = this.$refs.carousel; //监听对象
box.addEventListener("mouseover", () => {
this.mouseOver();
});
box.addEventListener("mouseout", () => {
this.mouseOut();
});
this.beginValue = this.begin;
this.play();
},
props: {
height: {
type: Number,
default: 600
},
dot: {
type: Boolean,
default: true
},
arrow: {
type: Boolean,
default: true
},
interval: {
type: Number,
default: 5000
},
begin: {
type: Number,
default: 0
},
slideData: {
type: Array,
default: function() {
return [];
}
}
}
};
</script>
<style scoped>
.slide {
position: relative;
margin: 0;
padding: 0;
overflow: hidden;
width: 100%;
height: 1.4rem;
}
.slide li {
list-style: none;
position: absolute;
width: 100%;
height: 1.4rem;
}
.slide li img {
/* width: 100%; */
height: 1.4rem;
cursor: pointer;
}
.slide li .title {
position: absolute;
left: 0;
bottom: 0;
padding: 10px 20px;
width: 100%;
/* background: rgba(0, 0, 0, 0.35); */
color: #fff;
font-size: larger;
text-align: center;
}
.videos {
width: 1.8rem;
height: 100%;
/* margin-top: 0.2rem; */
}
.videos:nth-child(1) {
margin-right: 0.2rem;
}
.slideDot {
position: absolute;
z-index: 999;
bottom: 0.2rem;
right: 1.85rem;
}
.slideDot span {
display: inline-block;
width: 0.07rem;
height: 0.07rem;
background: rgba(255, 255, 255, 0.65);
margin-left: 0.05rem;
}
.slideDot span.active {
background: rgba(255, 255, 255, 1);
}
.up,
.next {
position: absolute;
left: 0;
top: 85%;
margin-top: 0;
cursor: pointer;
width: 0.2rem;
height: 0.2rem;
background-repeat: no-repeat;
background-position: 50% 50%;
}
.up {
width: 0.2rem;
left: 0.25rem;
background-image: url("");
}
.next {
left: auto;
right: 0.25rem;
background-image: url("");
}
.up:hover {
/* background-color: rgba(0, 0, 0, 0.3); */
}
.next:hover {
/* background-color: rgba(0, 0, 0, 0.3); */
}
/*进入过渡生效时的状态*/
.slide-enter-active {
transform: translateX(0);
transition: all 1s ease;
}
/*进入开始状态*/
.slide-enter {
transform: translateX(-100%);
}
/*离开过渡生效时的状态*/
.slide-leave-active {
transform: translateX(100%);
transition: all 1s ease;
}
/*离开过渡的开始状态*/
.slide-leave {
transform: translateX(0);
}
/*进入过渡生效时的状态*/
.slideBack-enter-active {
transform: translateX(0);
transition: all 1s ease;
}
/*进入开始状态*/
.slideBack-enter {
transform: translateX(100%);
}
/*离开过渡生效时的状态*/
.slideBack-leave-active {
transform: translateX(-100%);
transition: all 1s ease;
}
/*离开过渡的开始状态*/
.slideBack-leave {
transform: translateX(0);
}
</style>
网友评论