javascript - 单独播放/暂停多个 HTML5 视频
问题描述
谁能帮我重新编写以下代码以在不使用 ID 的情况下工作,以便我可以将其用于单个页面上的多个视频?先感谢您!!
HTML MARKUP
<div id="video-container">
<video id="video" width="640" height="365" src="https://d3vv6lp55qjaqc.cloudfront.net/items/3V3g280Q1z441P071g3E/tnt-lidcap-web.mp4" type="video/mp4" autoplay loop muted></video>
<div id="video-controls">
<button id="play-pause" type="button" aria-label="toggle pause play">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 120 120" width="120" height="120">
<circle cx="60" cy="60" r="60" fill="#000" fill-opacity=".5" />
<path stroke="#fff" stroke-linecap="round" stroke-width="10" d="M74.933 33v54M45.067 33v54" id="pauseIcon" class="video-pause" style="visibility: visible" />
<path fill="#fff" stroke="#fff" stroke-linejoin="round" stroke-width="8" d="M54 33L54 87 81 60z" id="playIcon" class="video-play" style="visibility: hidden" />
</svg>
</button>
</div>
</div>
JAVASCRIPT (WORKS FOR SINGLE VIDEO)
window.onload = function() {
var video = document.getElementById("video");
var playButton = document.getElementById("play-pause");
var pauseIcon = document.getElementById("pauseIcon");
var playIcon = document.getElementById("playIcon");
playButton.addEventListener("click", function() {
if (video.paused == true) {
video.play();
pauseIcon.style.visibility ="visible";
playIcon.style.visibility ="hidden";
} else {
video.pause();
pauseIcon.style.visibility ="hidden";
playIcon.style.visibility ="visible";
}
});
}
Here is a link to my current working CodePen as well:
https://codepen.io/jhughes1006/pen/yZPVGo
解决方案
您可以替换class
每个id
并使用.querySelectorAll()
来执行相同的任务。
onload = e => {
const containers = document.querySelectorAll('.video-container'):
containers.forEach(container => {
const video = container.querySelector('video');
const playButton = container.querySelector('button');
playButton.addEventListener('click', e => {
// do stuff
})
})
}
推荐阅读
- c# - 在单个事务中在父子表中插入记录但是当发送多个对象时,我给出了错误实例!无法跟踪实例
- terraform - 如果值大于一,terraform 仅使用属性?
- python - 如何使用 Python 从另一个文件中的文本提取一个文件中的文本
- r - 根据重复次数和值过滤计数数据
- python - 如何简化 YAML 文件
- html - 右对齐 HTML 电子邮件
- ethereum - 松露测试:提供“结构”类型的方法参数?
- python - 使用规则列表插入分隔符
- json - Angular Material Nested 从服务中选择
- google-api - 获取 google 评论并创建与 Google API 一起使用的评论表单