简单实例:

  1. <audio id="myAudio"></audio>
  2. <script>
  3. var myAudio = document.getElementById('myAudio');
  4. myAudio.src = '../content/audio/海阔天空.mp3';
  5. myAudio.play();
  6. myAudio.loop = true;
  7. myAudio.preload = true;
  8. myAudio.currentTime
  9. </script>

Api说明:

1.如果需要显示缓存进度,可以参考:HTML5 Media事件

2.不能控制音频的二进制数据,如果需要处理二进制音频数据,参考HTML5 WebAudioAPI简介(一)

  1. 只读属性
  2. duration ---获取媒体文件的播放时长,以s为单位,如果无法获取则为NaN,当触发canplay事件后就可以获取当前总长度
  3. startTime---返回起始播放时间,一般是0.0,除非是缓冲过的媒体文件,并一部分内容已经不再缓冲区(此属性好像已经不可用)
  4. paused-----判断是否已经暂停,返回true/false
  5. ended-----判断是否已经播放完毕,返回true/false
  6. error----在发生了错误后,返回错误代码
  7. currentSrc --以字符串的形式发挥正在播放或已经加载的文件,对应浏览器在source元素中选择的文件
    buffered---获取当前缓冲区大小,返回TimeRanges对象,点击更多参考
  8.  
  9. 可控制属性
  10. src----指定音频的文件位置
  11. autoplay---是否自动播放
  12. preload----是否预加载
  13. loop------是否循环播放
  14. controls----显示或隐藏用户控制界面
  15. autobuffer---媒体文件播放前是否进行缓冲加载,如果设置了autoplay,则忽略此特性(此属性好像已经不可用)
  16. muted------设置是否静音
  17. volume ----在0.01.0间的音量值,或查询当前音量值
  18. currentTime--以s为单位返回从开始播放到目前所花的时间,也可设置currentTime的值来跳转到特定位置
  19.  
  20. 方法
  21. load() ---加载音频、视频软件
  22. paly() ---播放
  23. pause()---暂停
  24. canPlayType(obj) ----测试饭后指定指定的Mime类型的文件
  25.  
  26. 事件
  27. loadstart ---客户端开始请求数据
  28. progress----正在播放的时候不停触发,如果暂停不会触发,触发的时间间隔比较大
  29. play------play()和autopaly播放时,类似事件onplaying
  30. pause-----pause()方法触发时
  31. ended-----当结束播放时
  32. timeupdate----当前播放时间发生改变的时候,播放中常用的时间处理,如果暂停不会触发,触发的时间间隔比较小
  33. canplaythrough---歌曲已经载入完成
  34. canplay -----缓冲至可播放状态,类似事件onloadedmetadata
    onloadedmetadata----当元数据(比如分辨率和时长)被加载时运行的脚本

 更多属性

audioTracks----返回表示可用音频滚到的AudioTrackList对象。

controller---返回表示音频大年媒体控制器的MediaController对象。

crossOrigin---设置或返回音频的CORS设置

defaultMuted---设置或返回音频默认是否静音

defaultPlaybackRate---设置或返回音频的默认播放速度

mediaGroup---设置或返回音频叔叔的美肌组合的名称

networkState---返回音频的当前网络状态

playbackRate---设置或返回音频的播放速度。

seekable---返回标识音频可寻址不烦的TimeRanges对象

seeking---返回用户当前收正在音频中进行查找。

textTracks---返回标识文本滚到的TextTrackList对象

更多方法

load()----重新加载音频元素

getStartDate()----返回新的Date对象,表示当前时间线偏移量。

fastSeek()---在音频播放器中指定播放时间。

addTextTrack()----想音频添加新的文本轨道。

更多参考:http://caibaojian.com/html5-audio.html

实例1:

  1. <style>
  2. #volumeSlider .slider-selection {
  3. background:#bababa;
  4. }
  5. </style>
  6. <div class="container">
  7. <p>../content/audio/海阔天空.mp3</p>
  8. <button class="btn btn-primary" id="playBtn">
  9. <i class="glyphicon glyphicon-play"></i>
  10. </button>
  11. <button class="btn btn-info" id="mutedBtn">
  12. <i class="glyphicon glyphicon-volume-down"></i>
  13. </button>
  14. <button class="btn btn-danger" id="changeBtn">切换歌曲</button>
  15. <div class="form-group">
  16. <label class="control-label">音量:</label>
  17. <input class="form-control" id="volume" data-slider-id="volumeSlider"
  18. data-slider-min="0" data-slider-max="100" data-slider-step="1"
  19. />
  20. </div>
  21. </div>
  22. <audio id="myAudio"></audio>

js代码:

  1. var currentFile = '../content/audio/海阔天空.mp3';
  2. //判断浏览器是否支持audio
  3. if (!window.HTMLAudioElement) {
  4. alert('您的浏览器不支持audio标签');
  5. } else {
  6. var myAudio = document.getElementById('myAudio');
  7. //播放/暂停按钮
  8. $('#playBtn').click(function () {
  9. var icon = $(this).find('i');
  10. //播放
  11. if (myAudio.paused) {
  12. //如果延迟指定src的话,会在播放前有较长的等待
  13. if (myAudio.src.length <= 0) {
  14. myAudio.src = currentFile;
  15. }
  16. myAudio.play();
  17. icon.removeClass('glyphicon-play').addClass('glyphicon-pause');
  18. } else {
  19. myAudio.pause();
  20. icon.addClass('glyphicon-play').removeClass('glyphicon-pause');
  21. }
  22. });
  23. //静音按钮
  24. $('#mutedBtn').click(function () {
  25. var icon = $(this).find('i');
  26. icon.toggleClass('glyphicon-volume-down').toggleClass('glyphicon-volume-off');
  27. myAudio.muted = !myAudio.muted;
  28. });
  29. //音量按钮
  30. $('#volume').slider({
  31. value: myAudio.volume * 100
  32. }).on('change', function (e) {
  33. var value = e.value.newValue / 100;
  34. myAudio.volume = value;
  35. });
  36. $('#changeBtn').click(function () {
  37. //使用在线文件
  38. myAudio.src = 'http://m5.file.xiami.com/523/78523/1136455538/1774490672_16884267_l.mp3?auth_key=61ade10d6a7508618ab53fe2aaa39b8c-1478919600-0-null';
  39. myAudio.play();
  40. });
  41. //监听事件
  42. myAudio.oncanplay = function () {
  43. console.info('进入可播放状态,音频总长度:' + myAudio.duration);
  44. }
  45. myAudio.onplay = function () {
  46. console.info('开始播放:' + myAudio.currentTime);
  47. }
  48. myAudio.onpause = function () {
  49. console.info('暂停播放:' + myAudio.currentTime);
  50. }
  51. myAudio.onprogress = function () {
  52. //console.info(myAudio.buffered);
  53. //console.info('正在播放:' + myAudio.currentTime);
  54. }
  55. myAudio.ontimeupdate = function (e) {
  56. console.info('播放时间发生改变:'+myAudio.currentTime);
  57. }
  58. }

显示结果:

HTML5 <Audio>标签API整理(一)的更多相关文章

  1. HTML5 <Audio/>标签Api整理(二)

    1.实例2: 相对较完整 Html代码: <style> #volumeSlider .slider-selection { background:#bababa; } </styl ...

  2. HTML5 <Audio>标签API整理(三)

    一.浏览器支持 Internet Explorer 9+, Firefox, Opera, Chrome, 和 Safari 都支持 <audio> 元素. 注意: Internet Ex ...

  3. HTML5 Audio标签方法和函数API介绍

    问说网 > 文章教程 > 网页制作 > HTML5 Audio标签方法和函数API介绍 Audio APIHTML5HTML5 Audio预加载 HTML5 Audio标签方法和函数 ...

  4. CEF3 HTML5 audio标签为什么不能播放mp3格式的音频文件

    CEF3 HTML5 audio标签 为什么不能播放mp3格式的音频文件   原因略.   解决方法: 找一个最新版的chrome ,我用的是24版本.路径 C:\Documents and Sett ...

  5. html5 audio标签微信部分苹果手机不能自动播放音乐终极解决方案

    html5 audio标签微信部分苹果手机不能自动播放音乐终极解决方案 大家都知道需要在点击时候后 播放 ps:如果点击ajax 回来播放也不行,必须点击立即播放 要背景自动播放只能采取下面方案< ...

  6. html5 audio标签切换播放音乐的方法

    html5 audio标签切换播放音乐的方法<pre><audio id="music1" preload loop="loop">&l ...

  7. ios加载html5 audio标签用js无法自动播放

    html5 audio标签在ios 微信浏览器中是无法自动播放的,最近在做一个小的项目遇到这个问题,安卓和pc都是正常的,唯独ios不行,查阅了很多资料,找到了以下方法,也许不是最好用的方法,如果有更 ...

  8. 论HTML5 Audio 标签歌词同步的实现

    HTML5草案里面其实有原生的字幕标签(<track> Tag)的,但使用的是vtt格式的文件,非常规的字幕(.sub, .srt)或歌词文件(.lrc). 用法如下(代码来自W3Scho ...

  9. html5 -----audio标签

    在现在的公司上班需要做一个html5页面,上下可以滑动的,在页面上需要音乐,默认开始音乐播放,点击音乐标签后音乐停止.后来在项目开发中,遇到性能优化的问题,所以我建议大家以后在使用时不要直接在页面中使 ...

随机推荐

  1. [BZOJ 1081] [SCOI2005] 超级格雷码 【找规律】

    题目链接:BZOJ - 1081 备注:此题BZOJ上貌似没有 spj ,要把一般顺序的每个格雷码倒着输出...比如 0102 输出为 2010 题目分析 就是按照 Gray 码的生成方法写前几个出来 ...

  2. Sed&awk笔记之sed篇

    http://blog.csdn.net/a81895898/article/details/8482387 Sed是什么 <sed and awk>一书中(1.2 A Stream Ed ...

  3. 【 POJ - 1204 Word Puzzles】(Trie+爆搜|AC自动机)

    Word Puzzles Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 10782 Accepted: 4076 Special ...

  4. [SQL Server]一次执行资料夹内的.sql 指令码

    原文:[SQL Server]一次执行资料夹内的.sql 指令码 初始资料库时,我们Developers们会准备很多.sql指令码来建立资料表.检视甚至初始资料,那麽要怎麽一次执行资料夹内的*.sql ...

  5. Java中如何创建进程(转)

    在Java中,可以通过两种方式来创建进程,总共涉及到5个主要的类. 第一种方式是通过Runtime.exec()方法来创建一个进程,第二种方法是通过ProcessBuilder的start方法来创建进 ...

  6. Android入门-Service-start,end,bind,unbind之间的区别

    写贴一段别人关于service中start与bind,end与unbind的分析了: Service创建有两种方法:  startService或者bindService 服务不能自己运行,需要通过调 ...

  7. 利用MVC的过滤器实现url的参数加密和解密

    最近在与一个IOS应用做接口对接,之前一直都没有遇到什么很大的问题,但是有一天发现可以通过软件解析app的url,然后直接通过url的拼接修改接口数据,这一下使得数据的安全性和准确性都降低了,于是就想 ...

  8. main函数的3个参数

    最早是在MCU中使用C语言,MCU中的main函数没有参数. 后来在PC上面使用C语言,一般教程都写的是main函数有2个参数: int main(int argc, const char **arg ...

  9. 在Openstack H版部署Nova Cell 时 ,终端输入nova service-list 和 nova host-list 命令将报错

    关于Cell的基本介绍,可以参考贤哥的一篇文章: [OpenStack]G版中关于Nova的Cell  http://blog.csdn.net/lynn_kong/article/details/8 ...

  10. 2 storm的topology提交执行

    本博文的主要内容有 .storm单机模式,打包,放到storm集群 .Storm的并发机制图 .Storm的相关概念 .附PPT 打包,放到storm集群去.我这里,是单机模式下的storm. wee ...