javascript - 单击另一个音频元素时暂停音频
问题描述
我正试图重新回到我大约 4 个月前建立的项目中。我停止了这么长时间的编码,男孩我很挣扎。基本上,我的应用程序播放带有图像的歌曲被点击。问题是,如果您单击不同的图像,第一个音频会继续播放。我在这里想念什么?
<!DOCTYPE html>
<html lang="en">
<head>
<script src="Resources\js\p5.js"></script>
<script language="javascript" type="text/javascript" src="Resources\js\p5.dom.js"></script>
<link rel="stylesheet" type="text/css" href="Resources\css\style.css">
<title>Pressn.Listen</title>
</head>
<body>
<h1>Pressn.Listen</h1>
<section>
<ul id="image-list" style="list-style-type: none">
<li><input type="image" class="images" src="https://dl.dropboxusercontent.com/s/v4mfc9ql89q60hn/DSCF8693.jpg?dl=0" alt="pink-flowers"></input></li>
<li><input type="image" class="images" src="https://dl.dropboxusercontent.com/s/ywri0sg4i16nbc2/DSCF7307.jpg?dl=0" alt="overpass-sky"></input></li>
<li><input type="image" class="images" src="https://dl.dropboxusercontent.com/s/xpslama3reuniwz/DSCF6953.jpg?dl=0" alt="home-doorway"></input></li>
<li><input type="image" class="images" src="https://dl.dropboxusercontent.com/s/73xltoeeoyq78y7/20181029-DSCF6165.jpg?dl=0" alt="garage"></input></li>
</ul>
</section>
<footer>
<nav>
<ul id="nav-bar" style="list-style-type: none">
<li>
<a class="links" target="_blank" href="https://mobile.twitter.com/eddiepearson">Twitter</a>
</li>
<li>
<a class="links" target="_blank" href="https://github.com/eddiepearson">Github</a>
</li>
</ul>
</nav>
</footer>
<audio id="song1" src="Resources\sounds\loopy loop 1.mp3"></audio>
<audio id="song2" src="Resources\sounds\Automation city master.mp3"></audio>
</body>
<script type="text/javascript" src="Resources\js\app.js"></script>
</html>
@import url('https://fonts.googleapis.com/css?family=Roboto+Mono');
* {
margin: 0;
padding: 0;
box-sizing: border-box;
font-family: 'Roboto Mono', monospace;
}
body, html {
background-color: #f2f2f2;
}
body {
position: relative;
z-index: 2;
}
header {
text-align: right;
margin: 3rem;
}
h1 {
margin: 5rem 0 1rem 7rem;
background: linear-gradient(90deg, rgba(0,25,36,1) 0%, rgb(118, 181, 211) 0%, rgba(255,206,249,1) 36%);
-webkit-background-clip: text;
background-clip: text;
-webkit-text-fill-color: transparent;
}
#image-list {
margin: 8rem auto;
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
grid-gap: 10px;
max-width: 1000px;
}
.images {
display: block;
width: 100%;
height: 100%;
object-fit: cover;
border-radius: 10px;
border: none;
box-shadow: 5px 5px 0 0 rgba(19, 19, 19, 0.15);
}
.ease {
/* transition: transform 2.5s ease-out;
transform: translateY(4px);
transform: scale(2); */
animation-name: stretch;
animation-duration: 2.5s;
animation-timing-function: ease-out;
animation-delay: 0;
animation-direction: alternate;
animation-iteration-count: infinite;
animation-fill-mode: none;
animation-play-state: running;
}
@keyframes stretch {
0% {
transform: scale(.3);
}
50% {
}
100% {
transform: scale(1.5);
}
}
input:hover {
-webkit-filter: brightness(70%);
filter: brightness(70%);
transition: 0 3s ease;
}
#nav-bar {
display: flex;
justify-content: center;
margin: 5rem;
}
#nav-bar li {
margin: 2rem;
}
.links {
text-decoration: none;
padding: 1rem;
color: black;
box-shadow: 5px 5px 0 0 rgba(19, 19, 19, 0.15);
border-radius: 10px;
transition: 0s;
}
.links:hover {
color: white;
background: linear-gradient(90deg, rgba(0,25,36,1) 0%, rgba(54,123,156,1) 0%, rgba(198,153,192,1) 70%);
transition:.5s;
}
.links:after {
transform: translateY(4px);
}
@media screen and (max-width: 600px) {
#image-list {
margin: 3rem;
}
h1 {
margin: 5rem 3rem 10rem 3rem;
}
}
@media screen and (max-width: 1000px) {
#image-list {
margin: 3rem;
}
}
let animation = document.querySelector('.ease');
let img1 = document.querySelector('li:nth-child(1)');
let img2 = document.querySelector('li:nth-child(2)');
let song1 = document.querySelector('#song1');
let song2 = document.querySelector('#song2');
//play pause
img1.addEventListener('click', function() {
if(song1.paused) {
song1.play();
//this.classList.toggle('ease');
} else {
song1.pause();
//this.classList.toggle('ease');
}
});
img2.addEventListener('click', function() {
if(song2.paused) {
song2.play();
//this.classList.toggle('ease');
} else {
song2.pause();
//this.classList.toggle('ease');
}
});
解决方案
当您开始播放一首歌曲时,只需停止另一首歌曲。
img1.addEventListener('click', function() {
if(song1.paused) {
song2.pause(); // <--- this piece
song1.play();
} else {
song1.pause();
}
});
推荐阅读
- python - 网页抓取 : 在应答器中获取文本
内容 p 和脚本
- scrapy - 我可以安全地将 Scrapy 的 HttpCacheMiddleware 移近引擎吗?
- node.js - 使用 Sequelize 模型的问题,诸如“无法读取未定义的属性‘创建’”或未定义客户端等错误
- javascript - 将字符串转换为函数,给出 ReferenceError
- python - 在正则表达式中匹配两个字母
- linux - 如何为使用 ARCH_MULTIPLATFORM=y 的 ARM 平台指定物理内存偏移量?
- php - 如果我希望我的 Laravel 项目有多个单词,我应该如何命名它?
- python - 在 ListView 中注释 QuerySet:Django
- angular - Angular 6/7:仅从 API 获取数据一次,但显示在两个路由/视图中
- c++ - 使用 << 运算符从文件中读取无符号字符