
本文详细介绍了如何使用一套可扩展的javascript解决方案,实现页面上多个视频通过单个模态框(`
在现代Web开发中,展示多个视频内容并提供模态框播放体验是常见的需求。然而,为每个视频单独编写一套打开模态框、播放视频、关闭模态框的JavaScript代码,会导致代码冗余、难以维护,尤其当视频数量众多时。本教程将引导您构建一个高效、可扩展的解决方案,利用单个模态框和动态内容加载机制来管理所有视频的播放。
核心思想
本方案的核心在于“单一模态框,动态内容”。我们不再为每个视频创建独立的HTML模态框结构,而是使用一个通用的模态框元素。当用户点击某个视频的播放按钮或链接时,JavaScript会捕获这个事件,根据被点击的视频信息动态地更新模态框内视频播放器的src和poster属性,然后显示模态框并开始播放。同时,我们还将引入播放列表导航功能,允许用户在模态框内切换不同的视频。

HTML结构
为了实现上述功能,我们需要定义一个视频播放列表以及一个通用的模态框。这里我们使用HTML5的
<!-- 视频播放列表 -->
<ol class="playlist">
<a href="#" id="0"><b>40</b> Seconds</a>
<a href="#" id="1"><b>11</b> Seconds</a>
<a href="#" id="2"><b>08</b> Seconds</a>
</ol>
<!-- 通用视频播放模态框 -->
<dialog class="scroll">
<form id="ui" method="dialog">
<fieldset class="content">
<legend>
<input class="btn" type="submit" value="⨯"> <!-- 关闭按钮 -->
</legend>
<video controls></video> <!-- 视频播放器 -->
<fieldset class="control">
<input id="prev" class="btn" type="button" value="⏮"> <!-- 上一个视频按钮 -->
<output id="counter"></output> <!-- 当前视频索引显示 -->
<input id="next" class="btn" type="button" value="⏭"> <!-- 下一个视频按钮 -->
</fieldset>
</fieldset>
</form>
</dialog>登录后复制
结构说明:
立即学习“Java免费学习笔记(深入)”;
- playlist: 一个有序列表,其中每个标签代表一个视频。为了方便JavaScript识别,每个标签都分配了一个唯一的id,这个id将作为视频数组的索引。
- dialog: 这是HTML5原生的模态框元素。它默认是隐藏的,可以通过JavaScript的showModal()方法显示。
- form: 模态框内部的表单,method="dialog"属性允许通过表单提交关闭模态框。
- video: 模态框内的视频播放器,其src和poster属性将由JavaScript动态设置。
- prev / next: 用于在播放列表中切换视频的按钮。
- counter: 显示当前播放视频在列表中的序号。
CSS样式
为了使模态框和播放列表具有良好的视觉效果,我们需要一些CSS样式。以下是示例样式,您可以根据自己的设计需求进行调整。
*,
*::before,
*::after {
box-sizing: border-box;
}
html {
font: 300 5vmin/1 "Segoe UI"
}
body {
overflow: scroll
}
.playlist a {
display: list-item;
position: relative;
width: max-content;
color: #18272F;
text-decoration: none;
}
.playlist a+a {
margin-top: 0.5rem;
}
.playlist a::before {
content: '';
position: absolute;
width: 100%;
height: 0.1rem;
border-radius: 4px;
background-color: #18272F;
bottom: 0;
left: 0;
transform-origin: right;
transform: scaleX(0);
transition: transform .3s ease-in-out;
}
.playlist a:hover::before {
transform-origin: left;
transform: scaleX(1);
}
.playlist a b {
font-weight: 300;
font-family: Consolas;
font-size: 1.1rem;
}
dialog {
padding: 0;
border: 0;
border-radius: 5px;
background: transparent;
box-shadow: 0 10px 6px -6px #777;
}
dialog::backdrop {
background: rgba(50, 50, 50, 0.3);
}
#ui {
padding: 0;
border: 1.5px solid #bbb;
border-radius: 5px;
background: #eee;
}
.btn {
display: inline-flex;
justify-content: center;
align-items: center;
padding: 0;
border: 1px ridge #ddd;
border-radius: 5px;
font: inherit;
font-size: 2rem;
line-height: normal;
background: transparent;
cursor: pointer;
box-shadow: 0 6px 4px -4px #bbb;
}
.btn:hover {
box-shadow: 0 6px 8px -4px #999;
}
.btn:active {
transform: scale(0.95);
}
.content {
display: flex;
flex-flow: column nowrap;
justify-content: center;
align-items: center;
width: 100vh;
padding: 0 0.5rem;
border: 0;
background: #eee;
}
.content legend {
width: 100%;
}
.content legend .btn {
float: right;
padding-bottom: 0.45rem;
line-height: 0;
height: 1.5rem;
margin: 0.25rem -0.25rem 0.25rem 0;
color: #888;
}
.control {
display: flex;
justify-content: center;
align-items: center;
margin: 0 0 0.25rem;
padding: 0;
border: 0;
}
#prev,
#next {
width: 2rem;
height: 2rem;
padding: 0;
border: 0;
line-height: 1;
background: #eee;
}
#counter {
font-size: 1.15rem;
font-family: Consolas;
padding: 0 0.75rem;
}
video {
width: 100%;
}
.scroll::-webkit-scrollbar {
display: none;
}
.scroll {
-ms-overflow-style: none;
scrollbar-width: none;
}登录后复制
JavaScript逻辑
JavaScript是实现动态视频播放和模态框交互的核心。
标签: css javascript java html go html5 事件冒泡 懒加载 css动画 视频播放器 css样式
还木有评论哦,快来抢沙发吧~