alterar <audio> src com javascript

Eu tenho vários arquivos de áudio que eu quero transmitir com base no usuário seleciona. Como faço isso? Isto é o que eu tenho até agora e não parece funcionar.

* UPDATE: fez algumas mudanças e agora está alegando queaudio.load(); não é uma função. Alguém pode me dizer por que isso é? O código é atualizado para refletir as alterações.

JavaScript:

function updateSource(){ 
    var audio = document.getElementById('oggSource');
    audio.src = 
        'audio/ogg/' + 
        document.getElementById('song1').getAttribute('data-value');
    audio.load();
}

HTML:

<audio id="audio" controls="controls">
    <source id="oggSource" src="" type="audio/ogg"></source>
    <source id="mp3Source" type="audio/mp3"></source>
        Your browser does not support the audio format.
</audio>

<ul style="list-style: none">
    <li>Sunday May 27, 2012
        <ul style="display: none">
            <li id="song1" data-value="song1.ogg">
                <button onclick="updateSource();">Item1</button>
            </li>
            <li>Item2</li>
            <li>Item3</li>
        </ul>
    </li>
</ul>

Item2 eItem3 Eu vou querer reproduzir um arquivo de áudio diferente quando eles forem clicados.

questionAnswers(6)

yourAnswerToTheQuestion