tec*_*ant 9 javascript audio jquery html5 playback
我有一个包含10个左右缩略图的画廊,每个缩略图代表一首歌.为了控制每个的播放,我设置了一个播放按钮以通过jQuery淡入.在围绕Apple的开发中心进行一些挖掘之后,我找到了一些原生的JavaScript来控制音频.它工作得很漂亮,但是为了一次控制一个对象而编写.我想要做的是将其重写为一个动态控制您选择的缩略图的播放/暂停的功能.
下面是我发现的代码..工作,但是编写它10次是很多不必要的代码.
感谢您的帮助和建议,永远!
HTML:
<div class="thumbnail" id="paparazzixxx">
<a href="javascript:playPause();">
<img id="play" src="../images/icons/35.png" />
</a>
<audio id="paparazzi">
<source src="../audio/fernando_garibay_paparazzisnlmix.ogg" type="audio/ogg" />
<source src="../audio/fernando_garibay_paparazzisnlmix.mp3" type="audio/mpeg" />
Your browser does not support HTML5 audio.
</audio>
</div>
Run Code Online (Sandbox Code Playgroud)
JavaScript的:
<script type="text/javascript">
function playPause() {
var song = document.getElementsByTagName('audio')[0];
if (song.paused)
song.play();
else
song.pause();
}
</script>
Run Code Online (Sandbox Code Playgroud)
jes*_*vin 22
jQuery对于这类事情很棒.它使您能够根据元素与DOM树中其他元素的关系轻松操作元素.在您的示例中,您希望能够使<a>元素仅<audio>在单击时影响它们旁边的元素.
您当前的Javascript代码的问题在于它实际上只抓取整个页面上的第一个音频元素.
以下是如何更改代码以支持无限数量的<a> & <audio>对.
<a>标记中添加一个类(在我的示例中为'playback')HTML
<div class="thumbnail" id="paparazzixxx">
<a class="playback" href="#">
<img id="play" src="../images/icons/35.png" />
</a>
<audio id="paparazzi">
<source src="../audio/fernando_garibay_paparazzisnlmix.ogg" type="audio/ogg" />
<source src="../audio/fernando_garibay_paparazzisnlmix.mp3" type="audio/mpeg" />
Your browser does not support HTML5 audio.
</audio>
</div>
Run Code Online (Sandbox Code Playgroud)
使用Javascript
<script type="text/javascript">
$(function() {
$(".playback").click(function(e) {
e.preventDefault();
// This next line will get the audio element
// that is adjacent to the link that was clicked.
var song = $(this).next('audio').get(0);
if (song.paused)
song.play();
else
song.pause();
});
});
</script>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
49112 次 |
| 最近记录: |