本文介绍了2音频的声音,我想在同一时间打一HTML5音频元素的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问:我有2个音频的声音,我想在同一时间打一HTML5音频元素。

类似的帖子:

 < D​​IV>
&所述; H2物实施例1所述; / H2>
<音频ID =Sound1例子SRC = HTTP://geo-samples.beatport.com/lofi/5005876.LOFI.mp3控制=控制preLOAD =无>
< P>。您的浏览器不支持音频元素< / P>
< /音频>
< / DIV>< D​​IV>
&所述; H2物实施例2'; / H2>
<音频ID =SOUND2SRC = HTTP://geo-samples.beatport.com/lofi/5005933.LOFI.mp3控制=控制preLOAD =无>
< P>。您的浏览器不支持音频元素< / P>
< /音频>
< / DIV>

JavaScript的:

 变量$ =功能(ID){
返回的document.getElementById(ID);
}VAR sound1_click =功能(){
//开始播放
$(Sound1例子)打();
//暂停播放
$(SOUND2),暂停()。
}VAR sound2_click =功能(){
//开始播放
$(SOUND2)打();
//暂停播放
$(Sound1例子),暂停()。
}在window.onload =函数(){
$(Sound1例子)的onclick = sound1_click。
$(SOUND2)的onclick = sound2_click。
}


解决方案

我认为这个问题是你挂牌点击事件时,你应该听播放事件,也出于某种原因,的window.onload 不在的jsfiddle正常工作,所以替换

 的window.onload =函数(){
    $(Sound1例子)的onclick = sound1_click。
    $(SOUND2)的onclick = sound2_click。
}

  $(Sound1例子)onplay = sound1_click。
$(SOUND2)onplay = sound2_click。

或者你可以简单地概括它:

  VAR音频= document.getElementsByTagName('声音');
对于(VAR I = 0; I< audios.length;我++)音频[I] .onplay = pauseAllAudios.bind(NU​​LL,音频[I]);功能pauseAllAudios(音频){
    对于(VAR I = 0; I< audios.length;我++)
        如果(!音频[I] =音频)音频[I] .pause();
};

Question: I have 2 audio sounds and I want to play one HTML5 audio element at a time.

Similar Post: Play one HTML audio element at a time.

I saw a similar post to my question. However, as a JavaScript beginner I did not understand the code. So I tried a simpler way so I can understand, but is not working. I would appreciate any suggestions.

HTML5 code: (For this example only I used the same audio source as a previous post: http://jsfiddle.net/RE006/8djstmvy/

<div>
<h2>Example 1</h2>
<audio id="sound1" src=http://geo-samples.beatport.com/lofi/5005876.LOFI.mp3 controls="controls" preload="none">
<p>Your browser does not support the audio element.</p>
</audio>
</div>

<div>
<h2>Example 2</h2>
<audio id="sound2" src=http://geo-samples.beatport.com/lofi/5005933.LOFI.mp3 controls="controls" preload="none">
<p>Your browser does not support the audio element.</p>
</audio>
</div>

JavaScript:

var $ = function (id) {
return document.getElementById(id);
}

var sound1_click = function() {
//starts playing
$("sound1").play ();
//pause playing
$("sound2").pause();
}

var sound2_click = function() {
//starts playing
$("sound2").play ();
//pause playing
$("sound1").pause();
}

window.onload = function () {
$("sound1").onclick = sound1_click;
$("sound2").onclick = sound2_click;
}
解决方案

I think the problem is you are listing to click event, when you should be listening to play event, also for some reason, window.onload does not work properly in jsfiddle, so replace

window.onload = function () {
    $("sound1").onclick = sound1_click;
    $("sound2").onclick = sound2_click;
}

with

$("sound1").onplay = sound1_click;
$("sound2").onplay = sound2_click;

fiddle demo

or you can simply generalize it by:

var audios = document.getElementsByTagName('audio');
for(var i=0; i<audios.length;i++)    audios[i].onplay = pauseAllAudios.bind(null, audios[i]);

function pauseAllAudios(audio){
    for(var i=0; i<audios.length;i++)
        if(audios[i]!=audio)    audios[i].pause();    
};

fiddle demo

这篇关于2音频的声音,我想在同一时间打一HTML5音频元素的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

10-24 23:58