随着互联网的飞速发展以及HTML5的应用,越来越多的项目中用到video,audio当常用标签。

<audio> 标签属性

  1. <audio src="song.mp3" controls="controls" loop="loop" autoplay="autoplay"></audio>

当然audio元素允许多个 source 元素。source 元素可以链接不同的音频文件。浏览器将使用第一个可识别的格式:

再如下面:

  1. <audio controls="controls">
  2. <source src="music.ogg" />
  3. <source src="music.mp3" />
  4. <source src="music.wav" />
  5. </audio>

<video> 标签属性

下面先介绍下video标签的一般用法

video标签的属性如下:

注:control 属性供添加播放、暂停和音量控件。

一般用法:

  1. <div class="videoCon">
  2.   <video width="750" height="300" id="videoP" src="video.mp4"></video>
  3. </div>

当然可以暂停,播放该视频,使用方法如下:

  1. function playPause() {
  2. var myVideo = document.getElementById('videoP');
  3. if (myVideo.paused){
  4. myVideo.play();
  5. }else{
  6. myVideo.pause();
  7. }
  8. }

当然video 元素允许多个 source 元素。source 元素可以链接不同的视频文件。浏览器将使用第一个可识别的格式:

如下:

  1. <video width="320" height="240" controls="controls">
  2. <source src="movie.ogg" type="video/ogg">
  3. <source src="movie.mp4" type="video/mp4">
  4.  Your browser does not support the video tag.
  5. </video>

获取HTMLVideoElement和HTMLAudioElement对象

  1. //audio可以直接通过new创建对象
  2. Media = new Audio("http://www.abc.com/test.mp3");
  3. //audio和video都可以通过标签获取对象
  4. Media = document.getElementById("media");

Media方法和属性

  1. //错误状态
  2. Media.error; //null:正常
  3. Media.error.code; //1.用户终止 2.网络错误 3.解码错误 4.URL无效
  4.  
  5. //网络状态
  6. Media.currentSrc; //返回当前资源的URL
  7. Media.src = value; //返回或设置当前资源的URL
  8. Media.canPlayType(type); //是否能播放某种格式的资源
  9. Media.networkState; //0.此元素未初始化 1.正常但没有使用网络 2.正在下载数据 3.没有找到资源
  10. Media.load(); //重新加载src指定的资源
  11. Media.buffered; //返回已缓冲区域,TimeRanges
  12. Media.preload; //none:不预载 metadata:预载资源信息 auto:
  13.  
  14. //准备状态
  15. Media.readyState; //1:HAVE_NOTHING 2:HAVE_METADATA 3.HAVE_CURRENT_DATA 4.HAVE_FUTURE_DATA 5.HAVE_ENOUGH_DATA
  16. Media.seeking; //是否正在seeking
  17.  
  18. //回放状态
  19. Media.currentTime = value; //当前播放的位置,赋值可改变位置
  20. Media.startTime; //一般为0,如果为流媒体或者不从0开始的资源,则不为0
  21. Media.duration; //当前资源长度 流返回无限
  22. Media.paused; //是否暂停
  23. Media.defaultPlaybackRate = value; //默认的回放速度,可以设置
  24. Media.playbackRate = value; //当前播放速度,设置后马上改变
  25. Media.played; //返回已经播放的区域,TimeRanges,关于此对象见下文
  26. Media.seekable; //返回可以seek的区域 TimeRanges
  27. Media.ended; //是否结束
  28. Media.autoPlay; //是否自动播放
  29. Media.loop; //是否循环播放
  30. Media.play(); //播放
  31. Media.pause(); //暂停
  32.  
  33. //控制
  34. Media.controls; //是否有默认控制条
  35. Media.volume = value; //音量
  36. Media.muted = value; //静音
  37.  
  38. //TimeRanges(区域)对象
  39. TimeRanges.length; //区域段数
  40. TimeRanges.start(index) //第index段区域的开始位置
  41. TimeRanges.end(index) //第index段区域的结束位置

事件

  1. eventTester = function(e){
  2. Media.addEventListener(e,function(){
  3. console.log((new Date()).getTime(),e);
  4. });
  5. }
  6. eventTester("loadstart"); //客户端开始请求数据
  7. eventTester("progress"); //客户端正在请求数据
  8. eventTester("suspend"); //延迟下载
  9. eventTester("abort"); //客户端主动终止下载(不是因为错误引起),
  10. eventTester("error"); //请求数据时遇到错误
  11. eventTester("stalled"); //网速失速
  12. eventTester("play"); //play()和autoplay开始播放时触发
  13. eventTester("pause"); //pause()触发
  14. eventTester("loadedmetadata"); //成功获取资源长度
  15. eventTester("loadeddata"); //提示当前帧的数据是可用的
  16. eventTester("waiting"); //等待数据,并非错误
  17. eventTester("playing"); //开始回放
  18. eventTester("canplay"); //可以播放,但中途可能因为加载而暂停
  19. eventTester("canplaythrough"); //可以播放,歌曲全部加载完毕
  20. eventTester("seeking"); //寻找中
  21. eventTester("seeked"); //寻找完毕
  22. eventTester("timeupdate"); //播放时间改变
  23. eventTester("ended"); //播放结束
  24. eventTester("ratechange"); //播放速率改变
  25. eventTester("durationchange"); //资源长度改变
  26. eventTester("volumechange"); //音量改变

  

HTML5 audio与video标签实现视频播放,音频播放的更多相关文章

  1. 【转】解决chrome浏览器不支持audio和video标签的autoplay自动播放

    声音无法自动播放这个在 IOS/Android 上面一直是个惯例,桌面版的 Safari 在 2017 年的 11 版本也宣布禁掉带有声音的多媒体自动播放功能,紧接着在 2018 年 4 月份发布的 ...

  2. HTML5 Audio and Video 的新属性简介

    前言:HTML5 中 Audio and Video的使用方法比较简单,但就是比较复杂,方法属性多.如果不常用的几乎难以记住,甚至有些人难以区分不同属性和方法的作用,更别说应用了.以下对Audio a ...

  3. 检测是否支持HTML5中的Video标签

    //检测是否支持HTML5 function checkVideo() { if (!!document.createElement('video').canPlayType) { var vidTe ...

  4. Using HTML5 audio and video

    From:https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/Using_HTML5_audio_and_video Using HTML5 ...

  5. 让IE8支持html5中的video标签

    这是一篇综合几个前辈的解决方案. 使用video的时候,要遇到的问题. ①不兼容ie9及其以下版本 在<head>里添加两行, 参考张鑫旭前辈的博客,但是在ie8中薄播放. <!-- ...

  6. html5中的video标签和audio标签

    不管是否承认,flash早已不像过往那样如日中天了.亚马逊全面放弃flash.苹果放弃flash.安卓也放弃了移动端的flash支持.事实上flash已经不太适合web开发了,因为HTML5中的vid ...

  7. HTML插入音频和视频:audio和video标签及其属性

    一.上传到第三方网站,然后引入例如视频上传到优酷网,然后得到代码 <iframe height=498 width=510 src='http://player.youku.com/embed/ ...

  8. HTML5的Audio标签打造WEB音频播放器

    目前,WEB页面上没有标准的方式来播放音频文件,大多数的音频文件是使用插件来播放,而众多浏览器都使用了不同的插件.而HTML5的到来,给我们提供了一个标准的方式来播放WEB中的音频文件,用户不再为浏览 ...

  9. HTML中的<audio>和<video>标签讲解

    关于<audio>标签讲解:点击这里 这里来一段简单的html5的音频代码: <audio src="someaudio.wav"> 您的浏览器不支持 au ...

随机推荐

  1. QL Server 2008 所有账号丢失sysadmin权限,sa账号亦没有开启,该如何解决??

    1. 用Run as a administrator打开命令提示符里输入NET STOP MSSQLSERVER, 即停止MSSQLSERVER运行. 2. 在命令提示符里输入 NET START M ...

  2. appium for iOS config

    appium-doctor: Running iOS Checks ✔ Xcode is installed at /Applications/Xcode.app/Contents/Developer ...

  3. 在桌面程序上和Metro/Modern/Windows store app的交互(相互打开,配置读取)

    这个标题真是取得我都觉得蛋疼..微软改名狂魔搞得我都不知道要叫哪个好.. 这边记录一下自己的桌面程序跟windows store app交互的过程. 由于某些原因,微软的商店应用的安全沙箱导致很多事情 ...

  4. 求一个区间[a,b]中数字1出现的次数

    问题来源:http://ac.jobdu.com/problem.php?pid=1373 举例:如果n=10 那么1-10之间的1的个数是2(1,2,3,4,...10) 这其中有一个规律: 挨着看 ...

  5. linux的相关指令命令

    ls:查看当前所在的目录 whoami:查看当前所在的用户名 who:(查看所有的正在使用的用户名) id:唯一的识别编号(组所在的识别编号) uname  -a:显示当前操作系统的版本 cd:切换工 ...

  6. xss漏洞修复,待完善

    1.防止sql注入 /// <summary> /// 分析用户请求是否正常 /// </summary> /// <param name="Str" ...

  7. 转:大神提出来的java服务器方面面试问题(当作自己的学习目标平时得多注意)

    因为一些个人原因,陆陆续续参加了一些校招补招.社招的笔试和面试(BAT),也包括一些国外公司(Spotify, Google, Ericsson),最后有幸被网易收入麾下,拿到了S.下面罗列一些我复习 ...

  8. Maven创建工程 WEB

    http://www.zuidaima1.com/blog/1618180875144192.htm http://www.zuidaima1.com/blog/1618162161323008.ht ...

  9. Android中用TextView显示大量文字的方法

    最近学习Android中,试着实现一个简单的显示新闻Demo的时候,遇到了一个问题:一条新闻的内容文字很多,放在TextView上面超出屏幕了,怎么破? 查了一下资料,找到了两种方法实现: 1. 只用 ...

  10. C#创建文件夹,往里追字符串。

    /// <summary>写文本日志</summary> /// <param name="StrMessage">日志消息</param ...