- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在制作依赖于来自URL的流音频的软件,该URL用于存储在Google云端硬盘中的文件,在空闲大约5分钟后会超时并失败。这样做时,我希望刷新音频链接,并将时间设置为以前的音频。
要详细说明这个想法,请参见下面的示例代码:
export default class ReloadingAudio {
constructor(url) {
this.audio = new Audio(url)
this.audio.onerror = () => {
this.audio = new Audio(url)
}
}
}
第一次重新加载音频效果很好,但是由于创建的第二个新音频没有onerror功能,因此当再次超时时,不会重新加载音频。
export default class ReloadingAudio {
constructor(url) {
this.audio = new Audio(url)
const self = this
function onerrorFunction() {
self.audio = new Audio(url)
self.audio.onerror = onerrorFunction
}
this.audio.onerror = onerrorFunction
}
}
最佳答案
我不知道如何防止由Google云端硬盘引起的超时,但是您可以通过将src
重置为现有url
上的AudioElement
来获得预期的行为。
this.audio.onerror = () => {
this.audio.src = url;
}
关于javascript - 在Javascript中,如何在发生错误时反复/递归地重新加载Audio对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63208530/
我有一个小心理障碍:我有一个 html 中的 javascript 函数,可以在按下某个键时写入键码。我已经将它连接到一个函数,该函数可以准确地告诉我按下了什么字符和键码(不包括在内)。 我的问题是如
我上网已经有一段时间了,现在正试图解决这个问题。可以找到正在发生的事情的视频: https://i.gyazo.com/59fc489b6099b513c41aedeed482b8d2.mp4 $(d
我有一个 Python 程序,其中一个函数导入另一个脚本并运行它。但是脚本仅在第一次函数被调用时运行。 def Open_Generator(事件): 导入密码生成器 有什么建议吗? *该函数在 tk
我正在尝试在 git 中创建两个包含二进制文件的分支 - 一个“开发”分支和一个“稳定”分支。在我想将它们“发布”到稳定分支之前,开发分支可以对这些文件进行一些更改(并且稳定分支已重命名这些文件,以防
我在 IBM BlueMix 中的 Node Red 应用程序反复崩溃 - 每小时一次 - 除了“exited with status: 1.”之外没有任何真正的错误消息 如何解决此问题? 是否有来自
我是一名优秀的程序员,十分优秀!