Несколько источников - PullRequest
       0

Несколько источников

0 голосов
/ 30 октября 2011

Как мне заставить следующий скрипт воспроизводить несколько звуков? Я могу заставить его играть только один.

    <script>

// Mouseover/ Click sound effect- by JavaScript Kit (www.javascriptkit.com)
// Visit JavaScript Kit at http://www.javascriptkit.com/ for full source code

var html5_audiotypes={ //define list of audio file extensions
"mp3": "audio/mpeg",
"ogg": "audio/ogg",
}

function createsoundbite(sound){
var html5audio=document.createElement('audio')
if (html5audio.canPlayType){ //check support for HTML5 audio
    for (var i=0; i<arguments.length; i++){
        var sourceel=document.createElement('source')
        sourceel.setAttribute('src', arguments[i])
        if (arguments[i].match(/\.(\w+)$/i))
            sourceel.setAttribute('type', html5_audiotypes[RegExp.$1])
        html5audio.appendChild(sourceel)
    }
    html5audio.load()
    html5audio.playclip=function(){
        html5audio.pause()
        html5audio.currentTime=0
        html5audio.play()
    }
    return html5audio
}
else{
    return {playclip:function(){throw new Error("Your browser doesn't support HTML5 audio unfortunately")}}
    }
}

//Initialize sound clips with 1 fallback file each:

var mouseoversound=createsoundbite("/messages4u/2011/images/october/laugh.ogg", "/messages4u/2011/images/october/laugh.mp3")

</script>

HTML:

<area onmouseover="mouseoversound.playclip()" />

1 Ответ

2 голосов
/ 30 октября 2011

Ну, у вас есть только один <audio> элемент, как вы ожидаете, что он будет воспроизводить более одного звука?

Если вам нужны два звуковых эффекта, вам нужно два элемента <audio> (вы можете изменить источник только одного элемента, но он неопрятен и, вероятно, не будет работать так, как вы этого хотите).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...