我需要在我的页面上加载近20种声音。我想也许我需要分别只加载2个元素,这就是为什么你会看到inProgress属性
loadAudio: function () {
if (this.inProgress <= 1) {
this.inProgress++;
var elem = this.audioQueue.pop();
if (elem != null) {
var path = elem.Path + elem.Fileid + ((this.canPlayMp3) ? '.mp3' : '.wav');
audio = new Audio();
audio.src = "http://localhost:55578/~/x.mp3";
audio.addEventListener('loadedmetadata', function (e) { AudioPlayer.audioLoaded(e); }, false);
//audio.addEventListener('loadeddata', function (e) { AudioPlayer.audioLoaded(e); }, false);
audio.addEventListener('error', function (e) { AudioPlayer.audioLoaded(e); }, false);
if (elem.AudioType == AudioPlayerTypes.Keyboard) {
this.keyboardAudio[elem.Id] = audio;
}
}
}
audioLoaded: function (e) {
var t = e.target;
if (e.type == "error") {
var code = e.target.error.code;
console.log("error" + t.currentSrc + e.target.error.code);
} else {
console.log("loaded" + t.currentSrc);
}
this.inProgress--;
this.loadAudio();
}
正如你所看到的,我正在加载相同的声音仅用于测试但6个音频后出现同样的问题我有错误
LOG: loadedhttp://localhost:55578/~/x.mp3
LOG: loadedhttp://localhost:55578/~/x.mp3
LOG: loadedhttp://localhost:55578/~/x.mp3
LOG: loadedhttp://localhost:55578/~/x.mp3
LOG: loadedhttp://localhost:55578/~/x.mp3
LOG: loadedhttp://localhost:55578/~/x.mp3
LOG: errorhttp://localhost:55578/~/x.mp3 (4 - is error code)
它在Chrome,Firefox中非常酷,但在IE中却不行。 我找不到任何限制和解决方案。
另外一个问题:我读过有时候最好避免使用DOM元素,这就是为什么我要使用音频对象,因为我需要多次播放不同的元素。
答案 0 :(得分:1)
嗯它真的很奇怪,一般错误是正确的,因为IE没有免费资源。 在我的笔记本电脑上是充电器的问题,电脑真的很慢,今天我改变它,电脑工作得更快,声音在探险家正确加载:)