gpt4 book ai didi

javascript - 使用 jquery 播放声音并运行计时器

转载 作者:行者123 更新时间:2023-11-28 01:56:23 25 4
gpt4 key购买 nike

我尝试用下面的代码播放声音,但它不播放声音,所以我感到很难过,最后想在这里寻求你的帮助。

脚本

            $(function() {  
$('#btn_start').on('click', function(event){

event.preventDefault();
play_sound('mp3');
return false;
});


//------------------------
function play_sound(sound)
{
// 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();
}
});

最佳答案

我建议你创建一个像这样的小类:

无法在Javascript中获取持续时间(实际上并非在每个浏览器上都实现,您必须为每个“歌曲”设置此值)

fiddle :http://jsfiddle.net/XYevE/4/

(注意:这只是一个示例,开发速度非常快...:))

HTML:

<a href="#" id="btn_start">PLAY</a>
<div id="timer"><span>click play</span></div>
<div id="ms">
Before callback:
<span id="mins"></span>:
<span id="secs"></span>
</div>
<audio id="audiosource">
<source src="http://www.cumfortitudine.com/vvdemo/assets/js/actions/vquery.vdemo/scenes/assets/sound/hans-zimmer-injection.mp3" type="audio/mpeg" />
</audio>

Javascript:

    function myApp() { 
this.paused = false;
this.paused = true // set pause to true (stop)
this.isactive = false; // countdown is active
this.duration = 0; // set duration to 0 (get via audio DOM)
return this.observer(); // call and return the "observer" method of the "myApp" class
}

myApp.prototype.observer = function() { // observer method
var self = this; // set this to self (this is the current instance of this class)

$('#btn_start').on('click', function(event){ // where an user click on "btn_start"
event.preventDefault();
self.play('mp3'); // call the play method and store the state in a public var
self.countdown(self.onEnd); //parameter is the callback when the audio is finished
self.isactive = true;
});
return this; // return this instance
};

myApp.prototype.play = function() { // play method
var song = document.getElementById('audiosource');
this.duration = song.duration;
if (this.paused === true)
{
$('#btn_start').html('PAUSE');
console.log('set play song');
song.play();
this.paused = false;
}
else
{
$('#btn_start').html('PLAY');
console.log('set pause song');
song.pause();
this.paused = true;
}
return this;
};

myApp.prototype.countdown = function(duration, callback) { // countdown method
var self = this, // class instance
countdown = null, // countdown
ctx = null; // setIntervall clearer
timer = this.duration * 1000; // timer in milliseconds

if (this.isactive === true) // if this method yet called
{
return false;
}
countdown = function() {
if (timer <= 0)
{
self.isactive = false; // reset
clearInterval(ctx);
callback.call(this);
return false;
}
if (self.paused === false) // if not in pause
{
timer -= 250;
var mins = parseInt((timer / 1000) / 60);
var secs = parseInt((timer / 1000) - mins * 60);
$('#mins').html(mins);
$('#secs').html(secs);
$('#timer > span').html(timer.toFixed(2));
}
};
ctx = setInterval(countdown, 250);
};

myApp.prototype.onEnd = function() {
// when the audio is finish..
alert ('end of the song');
};

;$(function() {
new myApp();
});

关于javascript - 使用 jquery 播放声音并运行计时器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19038916/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com