记录前端视频加图片轮播操作

一、前言

突然接到个需求,用户觉得单纯的图片轮播展示太单调了,需要把视频加上,使用audio在谷歌 上自动播放视频加图片进行轮播操作,废话也不多说了
注:简单写了个示例代码,如需其它要求自行研究

二、实现代码

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>视频和图片轮播</title>
    <style>
        img{
            display: none;
        }
    </style>
</head>
<body>
<video id="video1" autoplay muted>
    <source src="img/20240129_163757.mp4" type="video/mp4">
</video>
<!--先隐藏第二个视频-->
<video id="video2" style="display:none;">
    <source src="img/20240129_165135.mp4" type="video/mp4">
</video>
<!--隐藏所有图片-->
<div id="imageCarousel" style="display: none;">
    <img src="img/evaluate_bg.png" alt="Image 1">
    <img src="img/img.png" alt="Image 2">
</div>
<script>
    var video1 = document.getElementById('video1');
    var video2 = document.getElementById('video2');
    var imageCarousel = document.getElementById('imageCarousel');
    var images = imageCarousel.getElementsByTagName('img');
    var currentIndex = 0;

    video1.addEventListener('ended', function () {
    	// 隐藏第一个视频
        video1.style.display = 'none';
        // 显示第二个视频
        video2.style.display = 'block';
        // 播放第二个视频
        video2.play();
    });
    video2.addEventListener('ended', function () {
    	// 隐藏第二个视频
        video2.style.display = 'none';
        // 显示图片信息
        imageCarousel.style.display = 'block';
        // 显示第一张图片
        images[currentIndex].style.display = 'block';
        // 第二个视频播放完后,轮播图片
        setTimeout(rotateImages, 5000);
    });

    function rotateImages() {
        images[currentIndex].style.display = 'none';
        currentIndex = (currentIndex + 1) % images.length;
        // 如果回到第一个图片,则播放第一个视频
        if (currentIndex === 0) {
            video1.style.display = 'block';
            video1.play();
        } else {
            images[currentIndex].style.display = 'block';
            setTimeout(rotateImages, 5000);
        }
    }
</script>
</body>
</html>
相关推荐
木易 士心11 分钟前
ESLint 全指南:从原理到实践,构建高质量的 JavaScript/TypeScript 代码
javascript·ubuntu·typescript
前端达人26 分钟前
都2026年了,还在用Options API?Vue组合式API才是你该掌握的“正确姿势“
前端·javascript·vue.js·前端框架·ecmascript
Dxy12393102161 小时前
Python检查JSON格式错误的多种方法
前端·python·json
AI周红伟1 小时前
周红伟:字节官方发布Seedance 2.0 视频模型,技术实现过程和 技术分解
音视频
chao-Cyril1 小时前
从入门到进阶:前端开发的成长之路与实战感悟
前端·javascript·vue.js
shalou29012 小时前
Spring 核心技术解析【纯干货版】- Ⅶ:Spring 切面编程模块 Spring-Instrument 模块精讲
前端·数据库·spring
大时光2 小时前
js 封装 动画效果
前端
大时光2 小时前
html翻页时钟 效果
前端
大猫子的技术日记2 小时前
2025 AI Agent 开发实战指南:从上下文工程到多智能体协作
前端·人工智能·bootstrap
前端达人2 小时前
被JavaScript忽视的Web Animations API:为什么说它是前端动画的真正未来?
开发语言·前端·javascript·ecmascript