作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
因此,我现在拥有此功能可以在页面上播放音频:
function startAudio(base) {
var audio = new Audio()
audio.volume = 0.7
audio.autoplay = true
audio.load()
audio.addEventListener('load', function(){
audio.play()
}, true)
audio.addEventListener('ended', function(){
this.currentTime = 0
this.play()
}, false)
audio.src = base + '/audio.wav'
var player = document.querySelector('.player')
if (player) {
player.addEventListener('click', togglePlay)
}
var isPlaying = false
audio.onplaying = function(){
isPlaying = true;
}
audio.onpause = function(){
isPlaying = false;
}
function togglePlay() {
if (isPlaying) {
audio.pause()
} else {
audio.play()
}
}
}
localStorage
或其他内容中,但是我不知道是否有一种方法可以在页面刷新或页面更改时自动播放。您有什么推荐的吗?我不能真正使它成为能够解决问题的单页应用程序(SPA),但不幸的是,它超出了该应用程序的范围。
最佳答案
就像您说的那样,使用localStorage:
function startAudio(base, offset = 0) {
var audio = new Audio()
audio.volume = 0.7
audio.currentTime = offset;
audio.autoplay = true
audio.load()
audio.addEventListener('load', function(){
audio.play()
}, true);
audio.addEventListener('ended', function(){
this.currentTime = 0;
this.play();
}, false);
// Reflect data to localStorage
localStorage.setItem("audio", base);
setInterval(() => {
localStorage.setItem("audio_time", audio.currentTime);
}, 100);
audio.src = base + '/audio.wav'
//...
}
if("audio" in localStorage) {
startAudio(
localStorage.getItem("audio"),
+localStorage.getItem("audio_time");
);
}
关于javascript - 如何在JavaScript中的刷新之间保持歌曲播放,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57291261/
我是一名优秀的程序员,十分优秀!