ユーザーの選択に基づいてストリーミングしたい複数のオーディオファイルがあります。それ、どうやったら出来るの?これは私がこれまでに持っているもので、うまくいかないようです。
*更新:いくつかの変更を行い、audio.load();
は関数ではないと主張しました。誰がそれがなぜなのか教えてもらえますか?コードが更新され、変更が反映されます。
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
およびItem3
クリックされたときに別のオーディオファイルを再生したいと思います。
このスニペットを試してください
list.onclick = function(e) {
e.preventDefault();
var Elm = e.target;
var audio = document.getElementById('audio');
var source = document.getElementById('audioSource');
source.src = Elm.getAttribute('data-value');
audio.load(); //call this to just preload the audio without playing
audio.play(); //call this to play the song right away
};
<ul style="list-style: none">
<li>Audio Files
<ul id="list">
<li><a href="#" data-value="http://media.w3.org/2010/07/bunny/04-Death_Becomes_Fur.oga">Death_Becomes_Fur.oga</a></li>
<li><a href="#" data-value="http://media.w3.org/2010/07/bunny/04-Death_Becomes_Fur.mp4">Death_Becomes_Fur.mp4</a></li>
<li><a href="#" data-value="http://media.w3.org/2010/11/rrs006.oga">rrs006.oga</a></li>
<li><a href="#" data-value="http://media.w3.org/2010/05/sound/sound_90.mp3">sound_90.mp3</a></li>
</ul>
</li>
</ul>
<audio id="audio" controls="controls">
<source id="audioSource" src=""></source>
Your browser does not support the audio format.
</audio>
JSFiddle http://jsfiddle.net/jm6ky/2/
交換:
audio.load();
で:
audio.play();
jQueryを使用:
$("#playerSource").attr("src", "new_src");
var audio = $("#player");
audio[0].pause();
audio[0].load();//suspends and restores all audio element
if (isAutoplay)
audio[0].play();
ReactおよびCJSX(Coffee JSX)Vitim.usソリューションに基づいて行った方法です。componentWillReceiveProps
を使用して、すべてを検出できましたプロパティが変更されたら、URLが将来の小道具と現在の小道具の間で変更されたかどうかを確認します。
@propTypes =
element: React.PropTypes.shape({
version: React.PropTypes.number
params:
React.PropTypes.shape(
url: React.PropTypes.string.isRequired
filename: React.PropTypes.string.isRequired
title: React.PropTypes.string.isRequired
ext: React.PropTypes.string.isRequired
).isRequired
}).isRequired
componentWillReceiveProps: (nextProps) ->
element = ReactDOM.findDOMNode(this)
audio = element.querySelector('audio')
source = audio.querySelector('source')
# When the url changes, we refresh the component manually so it reloads the loaded file
if nextProps.element.params?.filename? and
nextProps.element.params.url isnt @props.element.params.url
source.src = nextProps.element.params.url
audio.load()
状態の変化や強制的な再描画も機能しなかったため、このようにしなければなりませんでした。
タグにメタデータを保存する場合は、データ属性を使用します。
<li id="song1" data-value="song1.ogg"><button onclick="updateSource()">Item1</button></li>
属性を使用して、曲の名前を取得します
var audio = document.getElementById('audio');
audio.src='audio/ogg/' + document.getElementById('song1').getAttribute('data-value');
audio.load();
これを変える
audio.src='audio/ogg/' + document.getElementById(song1.ogg);
に
audio.src='audio/ogg/' + document.getElementById('song1');