html5 Audio标签

html5 Audio标签javascript 动态创建 audio 标签在页面中添加 audio 元素的方法主要是两种 一种是在 html 中加入 audio 代码 可以加入一些属性 autoplay preload 等 这些在之前的文章已经说过了 另外一种是 js 动态加载进来的 代码如下 varaudio document creatElement audio audio src audio source ogg

javascript动态创建audio标签

在页面中添加audio元素的方法主要是两种,一种是在html中加入audio代码,可以加入一些属性(autoplay,preload)等,这些在之前的文章已经说过了。另外一种是js动态加载进来的。代码如下:

另外audio的属性,preload有三种不同的载入方式,我们可以通过preload=”auto”来实现音频的自动加载,但是我们无法通过直观的方式了解音频加载的进度,以及是否准备播放。这里提供了一个“canplaythrough”事件来监听音频是否已经加载完成。代码示例如下:

 Preload Ready  

运行代码复制代码另存代码(提示:可以编辑后运行)

第一次运行时间会长一些,第二次运行由于文件已经缓存到本地,所以会直接弹出提示框。

javascript控制audio的播放,暂停,停止

js如何控制audio标签的播放比较简单,在上面好多案例中已经提到了。主要是audio.play();同样暂停也比较简单audio.pause();就能很轻易搞定,看到这里你估计以为想要停止的话,也会使用这种语义化的函数了,呵呵,其实不是这样的audio.stop()并不能停止audio的播放。

如果你需要停止或者重新播放audio,必须设置它的currentTime,可见如下语句:

audio.currentTime = 0;

下面我给出一个完成的示例,包括了开始播放,暂停播放,停止播放

 Preload Ready      

运行代码复制代码另存代码(提示:可以编辑后运行)

注意:以上代码中的停止加上了pause(),另外跳到50秒加上了play()。这里主要是因为一旦play开始运行无法停止的,所以需要设置currentTime后使得音频暂停。另外跳转到50秒后,加上play()的做法是如果音频在没有播放的情况下,跳转到50秒时音频不会自动播放;而如果音频在播放中,那么跳到50秒的时候还是播放的,这里的play()可以忽略。当然具体情况可以自行定义。

 javascript控制audio的声音大小:

控制声音的大小比较简单,大概同play,pause那一套一样,主要是多了一个参数。

示例:audio.volume = 0;//表示静音  audio.volume = 1; 表示声音最大 ,声音值可以取0-1之间

演示不写了,可以自己修改上面代码运行框中的内容。

javascript控制audio的快进,快退,以及显示进度与时长

控制快进,快退的原理比较简单,只不过是设置audio的currentTime,案例如下

比如:audio.currentTime += 10;//10秒快进

 Preload Ready     

运行代码复制代码另存代码(提示:可以编辑后运行)

关于显示进度的方法也不是很复杂,不过如果你想实现js配合css做一个进度条的模拟也许复杂一点。如果你对js以及css比较熟悉的话,解决的思路有很多。甚至可以做出很多酷炫的效果。我在这里只是点一下如何调用出该音频文件的时长以及播放到进度的时间。

调用出音频的时长不难解决 “audio.duration;” 就是了

调用处该文件的播放进度,这里需要用到一个时间监听。currentTime代表当前播放的时间,而且当currentTime改变的时候会触发timeupdate事件。因此,我们监听timeupdate,并且输出currentTime即可完成进度的判断。不多说,看示例代码:

 Preload Ready  总时长: 
  

当前播放:



html5 Audio标签

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/202540.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月19日 下午11:54
下一篇 2026年3月19日 下午11:54


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号