DoubleLi

qq: 517712484 wx: ldbgliet

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

本文将介绍HTML5中的视音频标签和对应的DOM对象。是相关资料的中文化版本,可以作为编写相关应用的简易中文参考手册。

一些约定

  • 所有浏览器:指支持HTML5的常见桌面浏览器,包括IE9+、Firefox3.5+、Chrome3.0+、Oprae10.5+、Safari3.0+等等,以及常见的移动平台浏览器,包括Firefox3.5+、Chrome3.0+、Safari3.0+。此外也包括同这些浏览器采用相同内核的一系列再包装版本,如国内很多的浏览器发行版。
  • 更新检测的浏览器版本为(2016.1.21):Firefox43.0.4、Chrome47.0.2526、IE11.0.9600、Opera33.0、Safari5.1.7(windows)、Safari(OSX)
  • 部分浏览器则给出具体的浏览器类型及版本号范围
  • 对于HTML标签中系列值为布尔值的属性,只要在标签中进行了定义即表示定义为true值,其实这些属性,只要进行了定义,且值不为false|0|""均表示为真。

音频标签

基本形式示例

 
<audio src=”resURI.mp3” controls=“controls”>
 
你的浏览器不支持audio标签
 
</audio>

或者

 
<audio controls=”controls” autoplay=”autoplay” loop=”loop” preload=”preload”>
 
<source src=”resURI-1.ogg” type=”audio/ogg”>
 
<source src=”resURI-2.mp3” type=”audio/mpeg”>
 
你的浏览器不支持audio标签
 
</audio>

主要标签属性定义及子标签介绍

  • autoplay="false|true":定义了则页面就绪后自动加载播放
  • controls="false|true":定义了则显示用户控制条
  • crossorigin="CORSString":定义下载资源时如何处理跨域问题。
  • loop="false|true":定义了则一直循环播放
  • preload="none|metadata|auto":定义了则页面加载时对媒体资源进行预加载来预备播放。如果定义了autoplay属性,则本属性被忽略
  • mediagroup="mediagroupString"(一般不被支持):分组音频播放
  • muted="true|false":定义是否静音
  • src="URI":定义要播放的资源URI
  • 子标签<source>用于定义一个可选的播放资源,一般包含src="URI" 和type="audioType"等属性定义,其中URI是资源的URI;audioType的常用值一般有audio/oggaudio/mpegaudio/mp4,用来指定资源的类型以方便判断是否支持。一个<audio>内可以定义多个<source>,但只能播放一个,这样的定义形式一般用于浏览器兼容处理,浏览器会加载第一个支持的资源形式而忽略掉其他的。

主要桌面浏览器支持情况(移动浏览器类似)

  • Ogg Vorbis格式: Firefox3.5+、Opera10.5+、Chrome3.0+、
  • MP3格式:IE9+、Chrome3.0+、Safari3.0+
  • WAV格式:Firefox3.5+、Opera10.5+、Safari3.0+

视频标签

基本形式示例

 
<video src="resURI.mp4" width="320" height="240" controls="controls">
 
浏览器不支持video标签
 
</video>

或者

 
<video width="320" height="240" controls=”controls” >
 
<source src=”resURI-1.ogg” type=”video/ogg”>
 
<source src=”resURI-2.mp4” type=”video/mp4”>
 
<track src="textTrack.vtt" kind="captions" srclang="en" label="Closed Captions" default="">
 
你的浏览器不支持audio标签
 
</video>

主要属性标签属性和子标签介绍

  • autoplay="false|true":定义了则页面就绪后自动加载播放
  • controls="false|true":定义了则显示用户控制条
  • crossorigin="CORSString":定义下载资源时如何处理跨域问题。
  • loop="false|true":定义了则一直循环播放
  • mediagroup="mediagroupString"(一般不被支持):分组音频播放
  • muted="true|false":定义是否静音
  • preload="none|metadata|auto":定义了则页面加载时对媒体资源进行预加载来预备播放。如果定义了autoplay属性,则本属性被忽略
  • poster="mediaURI":定义一个资源(一般是图片)显示视频封面信息
  • src="URI":定义要播放的资源URI
  • height="hxxpx":定义视频播放器的高
  • width="wxxpx":定义视频播放器的宽
  • 子标签<source>用于定义一个可选的播放资源,一般包含src="URI" 和type="videoType"等属性定义,其中URI是资源的URI;videoType的可能值一般有video/Oggvideo/mp4video/WebM,用来指定资源的类型以方便判断是否支持。一个<video>内可以定义多个<source>,但只能播放一个,这样的定义形式一般用于浏览器兼容处理,浏览器会加载第一个支持的资源形式而忽略掉其他的。
  • 子标签<track>用户定义一个textTrack轨道(一般用作字幕等)。一般包含src="textTrack.vtt"srclang="en"、 kind="captions"label="Closed Captions"以及default=""属性定义,其中kind属性定义字符串轨道的类型,主要有:
    • subtitles ——子标题
    • captions ——字幕
    • descriptions ——描述
    • chapters ——章节
    • metadata ——元数据

主要桌面浏览器支持情况(移动浏览器类似)

  • Ogg:Firefox3.5+、Opera10.5+、Chrome5.0+
  • MP4:IE9.0+、Chrome5.0+、Safari3.0+、Firefox35+(开始支持H.264这一常见编码)
  • WebM:Firefox4.0+、Opera10.6+、Chrome6.0
  • 3Gpp:Safari3.0+

音视频DOM参考

方法

当前在HTML5音视频DOM对象定义中主要有addTextTrack()(还未正式实现)、canPlayType()load()play()pause()方法。下面是各方法介绍。

addTextTrack() (所有浏览器都不支持)

用来向音视频添加文本轨道

  • 语法: audio|video.addTextTrack(kind,label,language)
  • 参数介绍:

    • kind:规定文本轨道的类型,可能值:

      • "subtitles"
      • "caption"
      • "descriptions"
      • "chapters"
      • "metadata"
    • label:字符串值,为文本轨道规定标签。用于对文本轨道进行标识。

    • language:双字母语言代码,规定文本轨道的语言。例如英语是en,中文是zh
  • 返回值:一个TextTrack对象,表示新的文本轨道。

  • 调用示例:

     
    text1=myVid.addTextTrack("caption");
     
    text1.addCue(new TextTrackCue("Test text", 01.000, 04.000,"","","",true));

    canPlayType() (所有主流浏览器均支持)

    用来检测浏览器对音视频格式支持情况

  • 语法: audio|video.canPlayType(type)

  • 参数介绍:

  • 返回值:一个String对象,表示支持的级别,可能值有:

    • "probably" - 最有可能支持
    • "maybe" - 可能支持
    • "" - (空字符串)不支持
  • 调用示例:

     
    myVid=document.createElement('video');
     
    isSupp=myVid.canPlayType(vidType+';codecs="'+codType+'"');

    load() (除Safari外所有主流浏览器均支持)

    更改资源后重新进行加载,没有返回值。注意: 仅仅是加载,并不会自动播放。

    • 语法: audio|video.load()
    • 调用示例:
       
      document.getElementById("mp4_src").src="movie.mp4";
       
      document.getElementById("ogg_src").src="movie.ogg";
       
      document.getElementById("video1").load();

      play()和 pause() (所有主流浏览器均支持)

      开始/暂停播放当前音视频,没有返回值。
    • 语法:audio|video.play()audio|video.pause()
    • 调用示例:
 
var myVideo=document.getElementById("video1");
 
function playVid(){
 
myVideo.play();
 
}
 
function pauseVid() {
 
myVideo.pause();
 
}

注意 并没有所谓的 stop() 方法,即没有停止方法,其效果可由load()代替。

属性

当前在HTML5音视频DOM对象定义中主要有audioTracksautoplaybufferedcontrollercontrolscrossOrigincurrentSrccurrentTimedefaultMuteddefaultPlaybackRatedurationendederrorloopmediaGroupmutednetworkStatepausedplaybackRateplayedpreloadreadyStateseekableseekingsrcstartDatetextTracksvideoTracksvolume,以及视频对象独有的videoWidthvideoHeight(注意: 一般对象的widthheight被支持,但不能获取正确的值)下面是各属性介绍。

videoWidthvideoHeight(所有浏览器都支持)

获取当前HTML5视频的宽和高。

  • 语法:video.videoWidthvideo.videoHeight
  • 值介绍:数值值,表征当前视频宽和高,如果视频未加载则都为0。
  • 调用示例:
 
myVid=document.getElementById("video1");
 
alert("视频"+myVid.videoWidth+",宽"+myVid.videoHeight+"高");

audioTracks (浏览器IE支持)

只读值,返回表示可用音轨的AudioTrackList类型对象

  • 语法:audio|video.audioTracks
  • 值介绍:一个以下标0开始的AudioTrackList类型对象,表示所有可用音轨。AudioTrackList类型对象有如下属性:

    • audioTrackList.length-可用音轨数量
    • audioTracks.getTrackById(id) - 通过id来获得 AudioTrack类型对象
    • audioTracks[index] - 通过 index 来获得 AudioTrack 对象

      一个AudioTrack 对象表示一条音轨,有如下属性:

    • id - 获得音轨的 id

    • kind - 获得音轨的类型(可以是 "alternative", "description", "main", "translation", "commentary", 或者 "" (空字符串))
    • label - 获得音轨的标签
    • language - 获得音轨的语言
    • enabled - 获得或设置音轨是否是活动的 (true|false)
  • 调用示例:

 
myVid=document.getElementById("video1");
 
alert(myVid.audioTracks.length);

autoplay (所有浏览器支持)

用于设置或者获取视音频对象是否加载后即开始播放的属性。

  • 语法:设置时audio|video.autoplay=true|false、获取时audio|video.autoplay
  • 值介绍:为bool类型值,可能值为true-表示加载后即开始播放,或false-表示不自动播放(默认)
  • 调用示例
     
    myVid=document.getElementById("video1");
     
    myVid.autoplay=true;
     
    myVid.load();

    buffered (所有浏览器支持)

    只读值,用于获得视音频加载缓冲情况。
  • 语法:audio|video.buffered
  • 值介绍:值为一个TimeRanges对象,表示对当前资源加载的情况。一个TimeRanges对象可以描述资源已经缓冲的情况,它有如下属性

    • lenght-已经缓冲范围的数量(因为视音频数据包传递问题,可能不一定连续,所以需要分段)
    • start(index) - 获得某个已缓冲范围的开始位置,以秒计
    • end(index) - 获得某个已缓冲范围的结束位置,以秒计

      注释:index是缓冲范围下标,从0开始计数到lenght-1

  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    lenght=myVid.buffered.lenght;
     
    out="视频有"+lenght+"段缓冲区,各段起始时间(秒)为:\n";
     
    for(var i=0;i<lenght;i++)
     
    out=out+"第"+(i+1)+"段Start: "+myVid.buffered.start(i)+" End: "+myVid.buffered.end(0)+"\n";
     
    alert(out);

    controller (所有主流浏览器都不支持)

    只读值,检测一个视频是否有对应的媒体控制器
    • 语法:audio|video.controller
    • 返回值:一个MediaController对象,表示音视频的媒体控制器。MediaController对象有如下属性/方法
      • buffered - 获得音视频的缓冲范围
      • seekable - 或者音视频的可寻址范围
      • duration - 获得音视频的时长
      • currentTime - 获得或设置音视频的当前播放位置
      • paused - 检测音视频是否已暂停
      • play() - 播放音视频
      • pause() - 暂停音视频
      • played - 检测音视频是否已播放过
      • defaultPlaybackRate - 获得或设置音视频的默认播放速率
      • playbackRate - 获得或设置音视频的当前播放速率
      • volume - 获得或设置音视频的音量
      • muted - 获得或设置音视频是否已静音
  • 调用示例:

     
    myVid=document.getElementById("video1");
     
    alert("Controller: " + myVid.controller);

    controls (所有浏览器支持)

    为音视频设置/获取对应的控件(用于控制播放,每种浏览器的样式不同)状态

  • 语法:

    • 设置:audio|video.controls=true|false
    • 获取:audio|video.controls
  • 值介绍:controls属性值是布尔值,为true表示显示控件,为false表示不显示控件
  • 关于控件的介绍:一个标准的音视频控件包括如下按钮
    • 播放
    • 暂停
    • 进度条
    • 音量
    • 全屏切换(仅视频)
    • 字幕(当可用时)
    • 轨道(当可用时)
  • 调用示例:

     
    myVid=document.getElementById("video1");
     
    myVid.controls=true;

    crossOrigin (除IE和Safari外所有浏览器支持)

    设置/返回 音视频对象的CORS(跨站共享)设置

  • 语法:

    • 设置:audio|video.crossOrigin="CORS-String"
    • 获取:audio|video.crossOrigin
  • 值介绍:crossOrigin属性值为CORS-String字符串,主要有4种情况
    • 空值即"":等效于anonymous模式,且
    • anonymous:anonymous状态
    • 没有定义(默认值):No CORS状态,注意 与anonymous状态的区别,表示忽略掉默认状态的一种特殊状态
    • use-credentials:对应Use Credentials状态
  • CORS(跨站共享)状态对资源获取影响:

    • 请求的URL与定义媒体资源页面同源、或者URL为data:URL、或者URL为about:blank则执行如下步骤:
    1. 去获取URL,并且带有manual redirect flag(手动重定向)标记
    2. 循环:利用获取算法判断获取结果是否需要重定向
    3. 在下面情况中选取一种恰当的步骤执行:
      • 如果获取为一个重定向,且重定向的目标和源不同源(简单讲就不在同一域名下),则设置URL为重定向URL,返回一个`
      • potentially CORS-enabled fetch`消息(此时,之后的行为会根据这里的处理进行响应——包括禁止/允许)等待交互处理(一般为浏览器展示一个提醒)
      • 如果为一个重定向,且目标同源,则直接重定向,跳到循环步骤
      • 不是重定向(指向具体资源),资源同源且有效,则获取解析展示
    • No CORS模式,且默认值被污染(可能根据前面的交互),而URL不同源:获取URL,即允许跨域
    • No CORS模式,且默认值为禁止(可能根据前面的交互),而URL不同源,则不获取URL,即不允许跨域
    • Anonymous或者Use Credentials状态,如果URL不同源,按下面步骤执行:
      1. 以URL执行一次cross-origin request跨域请求(向当前源),其中request URL设置为URL目标值,CORS referrer source部分设置为referrer sourcesource origin设置为当前源信息, omit credentials flag设置为Anonymous或者省略掉
      2. 等待cross-origin request status返回
      3. 根据返回值情况处理见:
        • 如果返回为not success(不成功),则禁止后续跨站获取,对于浏览器相当于获取不到相应资源
        • 如果返回为success(成功),则继续获取(即允许跨站访问)
  • 调用示例:

     
    myVid=document.getElementById("video1");
     
    myVid.crossOrigin=`anonymous`;

    currentSrc (所有浏览器支持)

    只读,取得当前实际播放资源URL,如果未设置则返回空字符串

  • 语法:audio|video.currentSrc
  • 返回值:为表示当前实际播放资源的URL,为空表示没播放
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    alert("Controller:"+myVid.currentSrc);

    currentTime (所有浏览器支持)

    设置/取得当前播放资源时间位置数值(以秒计),
  • 语法:
    • 设置:audio|video.currentTime=5
    • 获取:audio|video.currentTime
  • 值介绍:为表示当前实际播放的位置数值(以秒计)
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    cuT=myVid.currentTime;
     
    myVid.currentTime=cut+10;//向后跳10秒

    defaultMuted (只有浏览器Chrome、Firefox、Oprae支持)

    设置/获取音视频是否默认静音。注意,这个属性仅仅改变默认静音状态,而不是当前状态,要改变当前是否静音,需要使用muted属性。
  • 语法:
    • 设置:audio|video.defaultMuted=true
      • 获取:audio|video.defaultMuted
  • 值介绍:布尔值,为true表示音视频默认静音,为false(默认值)表示默认不静音
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    cuT=myVid.defaultMuted;
     
    myVid.defaultMuted=!cuT;//反置defaultMuted属性

    defaultPlaybackRate (只有浏览器Chrome、Firefox、Oprae支持)

    设置/获取音视频默认播放速度。注意,这个属性仅仅改变默认播放速度,而不是当前的播放速度,要改变当前是播放速度,需要使用playbackRate属性。
  • 语法:
    • 设置:audio|video.defaultPlaybackRate =playbackspeed
      • 获取:audio|video.defaultPlaybackRate
  • 值介绍:数值,为一般为-2.0-2.0,默认为1(表示正常速度),为负值则为后退播放。
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    playbackspeed=myVid.defaultPlaybackRate ;
     
    myVid.defaultPlaybackRate =(playbackspeed>1)?1:playbackspeed;//如果速度比1大(是快速)就恢复为1(标准速度)

    duration (所有浏览器支持)

    获取音视频长度值(以秒为单位)。注意因为媒体资源长度可能是根据数据包计算,也可能是写入metadata中,所以在加载中,对于写入metadata的,加载后就不会变化,对根据获取数据包计算的,可能这个值会不断发生改变(特别是对于较大的音频资源)
  • 语法:audio|video.duration
  • 值介绍:只读数值,如果获取为NaN表示还未设置音视频(没有初始化加载)。
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    myDur=myVid.duration ;
     
    alert("当前媒体长度为"+myDur+"秒");

    ended (所有浏览器支持)

    获取音视频播放是否结束状态
  • 语法:audio|video.ended
  • 值介绍:只读布尔值,如果获取为true表示还播放已结束,fasle表示还未结束。
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    if(myVid.ended)
     
    alert("当前媒体播放已结束");

    error (所有浏览器支持)

    获取音视频播放是否结束状态
  • 语法:audio|video.error一般用audio|video.error.code
  • 值介绍:只读值,返回一个MediaError对象值,MediaErrorcode属性(一个数值属性)标识了错误类型。code值有:

    • 1 = MEDIA_ERR_ABORTED - 取回过程被用户中止
    • 2 = MEDIA_ERR_NETWORK - 当下载时发生错误
    • 3 = MEDIA_ERR_DECODE - 当解码时发生错误
    • 4 = MEDIA_ERR_SRC_NOT_SUPPORTED - 不支持音频/视频
  • 调用示例:

     
    myVid=document.getElementById("video1");
     
    alert(myVid.error.code);

    loop (所有浏览器支持)

    设置/获取音视频播放是否结束后循环播放

  • 语法:
    • 获取:audio|video.loop
    • 设置:audio|video.loop=true
  • 值介绍:布尔值,为true表示要循环播放,fasle(默认值)表示不循环播放。
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    if(myVid.loop)
     
    alert("当前媒体播放会循环播放");

    mediaGroup (所有浏览器都不支持)

    设置/获取多个音视频播放是组成一个组(从而同步播放)
  • 语法:
    • 获取:audio|video.mediaGroup
    • 设置:audio|video.mediaGroup="test"
  • 值介绍:字符串值,在一个页面中所有同组(mediaGroup值相同的)媒体会同步播放。
  • 调用示例:
     
    myVid1=document.getElementById("video1");
     
    myVid2=document.getElementById("video2");
     
    myVid1.mediaGroup="test";
     
    myVid2.mediaGroup="test";
     
    //至此,两个媒体就会同步播放啦

    muted (所有浏览器支持)

    设置/获取当前音视频是否静音。
  • 语法:
    • 设置:audio|video.muted=true
      • 获取:audio|video.muted
  • 值介绍:布尔值,为true表示音视频静音,为false(默认值)表示不静音
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    cuT=myVid.muted;
     
    myVid.muted=!cuT;//反置muted属性——即静音开关

    networkState (所有浏览器支持)

    获取音视频播放是否结束状态
  • 语法:audio|video.networkState一般用audio|video.error.code
  • 值介绍:只读值,返回返回音频/视频的当前网络状态(activity):
    • 0 = NETWORK_EMPTY - 音频/视频尚未初始化
    • 1 = NETWORK_IDLE - 音频/视频是活动的且已选取资源,但并未使用网络
    • 2 = NETWORK_LOADING - 浏览器正在下载数据
    • 3 = NETWORK_NO_SOURCE - 未找到音频/视频来源
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    alert(myVid.networkState);

    paused (所有浏览器支持)

    设置/获取当前音视频是暂停。
  • 语法:
    • 设置:audio|video.paused=true
      • 获取:audio|video.paused
  • 值介绍:布尔值,为true表示音视频暂停播放,为false表示没有暂停
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    cuT=myVid.paused;
     
    myVid.paused=!cuT;//反置paused属性——即暂停开关

    playbackRate (所有浏览器支持)

    设置/获取当前音视频默认播放速度。
  • 语法:
    • 设置:audio|video.playbackRate =playbackspeed
      • 获取:audio|video.playbackRate
  • 值介绍:数值,为一般为-2.0-2.0,默认为1(表示正常速度),为负值则为后退播放。
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    playbackspeed=myVid.playbackRate ;
     
    myVid.playbackRate =(playbackspeed>1)?1:playbackspeed;//如果速度比1大(是快速)就恢复为1(标准速度)

    played (所有浏览器支持)

    获取当前音视频默认播放速度。
  • 语法:audio|video.played常用audio|video.played.start(0)和 audio|video.played.end(0)
  • 值介绍:只读对象值,返回TimeRanges对象。一个TimeRanges对象标记了当前已经播放的范围,一个TimeRanges对象有如下属性:

    • length - 获得音频/视频中已播范围的数量
    • start(index) - 获得某个已播范围的开始位置(秒计,index<length)
    • end(index) - 获得某个已播范围的结束位置(秒计,index<length)

    注释: 首段已播放范围的下标是0。

  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    alert("已经播放: " + myVid.played.start(0) + " 到: " + myVid.played.end(0));

    preload (所有浏览器支持)

    设置/获取音视频是否在页面加载后自动进行加载。
  • 语法:
    • 设置:audio|video.preload="auto|metadata|none"
      • 获取:audio|video.preload
  • 值介绍:字符串值,为auto表示音视频自动加载,为metadata表示仅加载元数据,为none表示不自动加载
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    alert(myVid.preload);//显示当前视音频预加载设置
     
    myVid.preload="auto";//将当前视音频设置为自动加载——后面进行切换源属性后也会自动加载

    readyState (所有浏览器支持)

    只读获取音视频就绪状态。
  • 语法:audio|video.readyState
  • 值介绍:数值值,各值描述如下:

    • 0 = HAVE_NOTHING - 没有关于音频/视频是否就绪的信息
    • 1 = HAVE_METADATA - 关于音频/视频就绪的元数据
    • 2 = HAVE_CURRENT_DATA - 关于当前播放位置的数据是可用的,但没有足够的数据来播放下一帧/毫秒
    • 3 = HAVE_FUTURE_DATA - 当前及至少下一帧的数据是可用的
    • 4 = HAVE_ENOUGH_DATA - 可用数据足以开始播放
  • 调用示例:

     
    myVid=document.getElementById("video1");
     
    if(myVid.readyState=4){//如果就绪
     
    myVid.play();//开始播放
     
    }

    seekable (所有浏览器支持)

    只读获取音视频可寻址范围

  • 语法:audio|video.seekable
  • 值介绍:返回 TimeRanges 对象。TimeRanges 对象表示音频/视频中用户可寻址的范围。可寻址范围指的是用户在音频/视频中可寻址(可直接移动播放的位置)的时间范围。对于流视频,通常可以寻址到视频中的任何位置,即使其尚未完成缓冲TimeRanges 对象有如下属性:

    • length - 获得音频/视频中可寻址范围的数量
    • start(index) - 获得可寻址范围的开始位置
    • end(index) - 获得可寻址范围的结束位置

      注释: 第一个可寻址范围的下标是 index 0。

  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    alert("开始: " + myVid.seekable.start(0) + " 结束: " + myVid.seekable.end(0));

    seeking (所有浏览器支持)

    只读获取音视频是否真正寻址定位
  • 语法:audio|video.seeking
  • 值介绍:返回布尔值,true表示正在寻址,false表示没有寻址。
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    document.getElementById("span1").innerHTML=("定位中: " + myVid.seeking);

    src (所有浏览器支持)

    设置(一般不用做获取)音视频资源URL,要获取请用currentSrc属性
  • 语法:
    • 设置:audio|video.src=URL
  • 值介绍:URL字符串,指示资源URL,可以采用相对或者绝对路径。
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    myVid.src="movie.ogg";

    textTracks(除Safari(windows下的)外所有浏览器支持)

    只读获取音视频中可用的文本轨道
  • 语法:audio|video.textTracks
  • 值介绍:TextTrackList对象,表示当前视音频中所有可用的文本轨道。TextTrackList对象有如下属性:

    • length:获得音频/视频中可用的文本轨道的数量
    • [index] - 根据下标来获得 TextTrack对象(即一条文本轨道信息——包含一系列字符串信息,如字幕信息),从0开始下标。一个TextTrack对象又包含如下属性(方法):
      • kind - 获得文本轨道的类型(可以是 "subtitles", "caption", "descriptions", "chapters" 或者 "metadata")
      • label - 获得文本轨道的标签
      • language - 获得文本轨道的语言
      • mode - 获得或设置该轨道是否是活动的 ("disabled"|"hidden"|"showing")
      • cues - 获得 TextTrackCueList 对象的 cues 列表
      • activeCues - 获得 TextTrackCueList 对象形式的当前活动文本轨道 cues
      • addCue(cue) - 向 cues 列表添加一个 cue
      • removeCue(cue) - 从 cues 列表删除一个 cue
  • 调用示例:

     
    myVid=document.getElementById("video1");
     
    alert(myVid.textTracks.length+"条文本轨道");

    videoTracks (所有浏览器都不支持)

    只读获取音视频时间线偏移

  • 语法:video.videoTracks(注意: 只有video对象才可能有这个属性)
  • 值介绍:返回VideoTrackList对象值,表示当前表示视频的可用视频轨道。VideoTrackList对象有如下属性:

    • length - 获得视频中可用视频轨道的数量
    • getTrackById(id) - 通过 id 获得 VideoTrack 对象
    • [index] - 通过下标获得 VideoTrack 对象
    • selectedIndex - 获得当前 VideoTrack 对象的下标

      注释:第一个可用 VideoTrack 对象的下标是 0。

      一个VideoTrack 对象有如下属性:

      • id - 获得视频轨道的 id
      • kind - 获得视频轨道的类型(可以是 "alternative", "captions", "main", "sign", "subtitles", "commentary", 或 "" (空字符串))
      • label - 获得视频轨道的标签
      • language - 获得视频轨道的语言
      • selected - 获得或设置视频轨道是否是活动的 (true|false)
  • 调用示例:

     
    myVid=document.getElementById("video1");
     
    alert(myVid.videoTracks.length+"条视频轨");

    volume (所有浏览器支持)

    设置/获取音视频音量

  • 语法:
    • 获取:audio|video.volume
    • 设置:audio|video.volume=volumevalue
  • 值介绍:数值值,范围为0.0-1.01.0(默认)是最大音量,0.0是静音。
  • 调用示例:
     
    myVid=document.getElementById("video1");
     
    myVid.volume=0.2;//设置为20%音量

    事件

    当前在HTML5音视频DOM对象定义中主要有abortcanplaycanplaythroughdurationchangeemptiedendederrorloadeddataloadedmetadataloadstartpauseplayplayingprogressratechangeseekedseekingstalledsuspendtimeupdatevolumechangewaiting等事件可以侦测使用。下面是各事件介绍。

abort(所有浏览器支持)

当视音频在加载中被用户放弃时触发。error属性有MEDIA_ERR_ABORTED错误码,networkState属性为NETWORK_EMPTY或者NETWORK_IDLE状态。

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onabort=alert("视频加载被终止!");

此外还可以在标签中定义使用,例如:

 
<audio|video onabort="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("abort", function(){
 
//SomeJavaScriptCode
 
}
 
);

canplay (所有浏览器支持)

当浏览器能够开始播放指定的音频/视频时,发生 canplay 事件。当音频/视频处于加载播放过程中时(能正常播放情况下),会依次发生以下事件:

  1. loadstart
  2. durationchange
  3. loadedmetadata
  4. loadeddata
  5. progress
  6. canplay
  7. canplaythrough

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.oncanplay=alert("可以开始播放视频啦");

此外还可以在标签中定义使用,例如:

 
<audio|video oncanplay="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("canplay", function(){
 
//SomeJavaScriptCode
 
}
 
);

canplaythrough (所有浏览器支持)

当浏览器预计能够在不停下来进行缓冲的情况下持续播放指定的音频/视频时,会发生 canplaythrough 事件。可以用来提示状态。redyState属性变得大于等于HAVE_FUTURE_DATA

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.oncanplaythrough=alert("视频可一直播放");

此外还可以在标签中定义使用,例如:

 
<audio|video oncanplaythrough="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("canplaythrough", function(){
 
//SomeJavaScriptCode
 
}
 
);

durationchange (所有浏览器支持)

当指定音频/视频的时长数据发生变化时,发生 durationchange 事件。

当音频/视频加载后,时长将由 "NaN" 变为音频/视频的实际时长。

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.ondurationchange=alert("视频持续时间已经变化");

此外还可以在标签中定义使用,例如:

 
<audio|video ondurationchange="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("durationchange", function(){
 
//SomeJavaScriptCode
 
}
 
);

emptied (所有浏览器支持)

当指定音频/视频目前的播放列表为空时,发生 emptied 事件。networkState属性值变为NETWORK_EMPTY

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onemptied=alert("播放列表为空");

此外还可以在标签中定义使用,例如:

 
<audio|video onemptied="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("emptied", function(){
 
//SomeJavaScriptCode
 
}
 
);

ended (所有浏览器支持)

当指定音频/视频目前的播放列表已结束时,发生 ended 事件。此时currentTime值等于媒体资源最大值,且ended属性值为true

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onended=alert("播放列表已结束");

此外还可以在标签中定义使用,例如:

 
<audio|video onended="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("ended", function(){
 
//SomeJavaScriptCode
 
}
 
);

error (所有浏览器支持)

当指定音频/视频目前的播放列表已结束时,发生 error 事件。error属性对象有MEDIA_ERR_NETWORK以上的错误码,networkState属性为NETWORK_EMPTY或者NETWORK_IDLE状态。

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onerror=alert("发生错误");

此外还可以在标签中定义使用,例如:

 
<audio|video onerror="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("error", function(){
 
//SomeJavaScriptCode
 
}
 
);

loadeddata (所有浏览器支持)

当前帧的数据已加载,但没有足够的数据来播放指定音频/视频的下一帧时,会发生 loadeddata 事件。readyState属性变为大于等于HAVE_CURRENT_DATA

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onloadeddata=alert("当前帧加载完毕");

此外还可以在标签中定义使用,例如:

 
<audio|video onloadeddata="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("loadeddata", function(){
 
//SomeJavaScriptCode
 
}
 
);

loadedmetadata (所有浏览器支持)

当指定的音频/视频的元数据已加载时,会发生 loadedmetadata 事件。readyState属性变为大于等于HAVE_METADATA

音频/视频的元数据包括:时长、尺寸(仅视频)以及文本轨道。

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onloadedmetadata=alert("元数据信息加载完毕");

此外还可以在标签中定义使用,例如:

 
<audio|video onloadedmetadata="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("loadedmetadata", function(){
 
//SomeJavaScriptCode
 
}
 
);

loadstart (所有浏览器支持)

当浏览器开始寻找指定的音频/视频时,会发生 loadstart 事件。即当加载过程开始时。networkState属性等于NETWORK_LOADING

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onloadstart=alert("开始加载播放");

此外还可以在标签中定义使用,例如:

 
<audio|video onloadstart="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("loadstart", function(){
 
//SomeJavaScriptCode
 
}
 
);

pause (所有浏览器支持)

当音频/视频已暂停时时,会发生 pause 事件。此时paused属性会变成true

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onpause=alert("播放暂停");

此外还可以在标签中定义使用,例如:

 
<audio|video onpause="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("pause", function(){
 
//SomeJavaScriptCode
 
}
 
);

play (所有浏览器支持)

当音频/视频已开始或不再暂停时,会发生 play 事件。此时paused属性会变成false

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onplay=alert("播放中");

此外还可以在标签中定义使用,例如:

 
<audio|video onplay="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("play", function(){
 
//SomeJavaScriptCode
 
}
 
);

playing (所有浏览器支持)

当音频/视频在已因缓冲而暂停或停止后已就绪时,会发生 playing 事件。此时readyState值要变得等于或者大于HAVE_FUTURE_DATA,且paused属性值为false;或者readyState值要等于或者大于HAVE_FUTURE_DATA,而paused属性值变为false

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onplaying=alert("播放恢复");

此外还可以在标签中定义使用,例如:

 
<audio|video onplaying="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("playing", function(){
 
//SomeJavaScriptCode
 
}
 
);

progress (所有浏览器支持)

当浏览器正在下载指定的音频/视频时,会发生 progress 事件。networkState属性等于NETWORK_LOADING

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onprogress=alert("数据加载中");

此外还可以在标签中定义使用,例如:

 
<audio|video onprogress="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("progress", function(){
 
//SomeJavaScriptCode
 
}
 
);

ratechange (所有浏览器支持)

当音频/视频的播放速度已更改时,会发生 ratechange 事件。

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onratechange=alert("播放速度调整了");

此外还可以在标签中定义使用,例如:

 
<audio|video onratechange="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("ratechange", function(){
 
//SomeJavaScriptCode
 
}
 
);

resize (浏览器Chrome支持)

视频的播放区域大小更改时(videoWidthvideoHeight属性发生变化时),会发生 resize 事件。但readyState属性值不会是HAVE_NOTHING

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onresize=alert("播放大小变化了");

此外还可以在标签中定义使用,例如:

 
<audio|video onresize="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("resize", function(){
 
//SomeJavaScriptCode
 
}
 
);

seeked (所有浏览器支持)

当用户已移动/跳跃到音频/视频中的新位置时,会发生 seeked 事件。

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onseeked=alert("已经重新定位");

此外还可以在标签中定义使用,例如:

 
<audio|video onseeked="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("seeked", function(){
 
//SomeJavaScriptCode
 
}
 
);

seeking (所有浏览器支持)

当用户开始移动/跳跃到音频/视频中的新位置时,会发生 seeking 事件。

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onseeking=alert("重新定位中");

此外还可以在标签中定义使用,例如:

 
<audio|video onseeking="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("seeking", function(){
 
//SomeJavaScriptCode
 
}
 
);

stalled (所有浏览器支持)

当浏览器尝试获取媒体数据,但数据不可用时,会发生 stalled 事件。networkState属性值为 NETWORK_LOADING

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onstalled=alert("数据不可用");

此外还可以在标签中定义使用,例如:

 
<audio|video onstalled="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("stalled", function(){
 
//SomeJavaScriptCode
 
}
 
);

suspend (所有浏览器支持)

当浏览器刻意不获取媒体数据时(权限、跨域等等问题),会发生 suspend 事件。networkState属性等于NETWORK_IDLE

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onsuspend=alert("不允许获取数据");

此外还可以在标签中定义使用,例如:

 
<audio|video onsuspend="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("suspend", function(){
 
//SomeJavaScriptCode
 
}
 
);

timeupdate (所有浏览器支持)

当目前的播放位置已更改时,会发生 timeupdate 事件,一般用来更新指示器,也可以用于同步。

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.ontimeupdate=alert("播放头已移动");

此外还可以在标签中定义使用,例如:

 
<audio|video ontimeupdate="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("timeupdate", function(){
 
//SomeJavaScriptCode
 
}
 
);

volumechange (所有浏览器支持)

当音量已更改时,会发生 volumechange 事件,一般用来更新指示器。

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onvolumechange=alert("音量已变化");

此外还可以在标签中定义使用,例如:

 
<audio|video onvolumechange="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("volumechange", function(){
 
//SomeJavaScriptCode
 
}
 
);

waiting (所有浏览器支持)

当视频由于需要缓冲下一帧而停止,会发生 waiting 事件。此时readyState属性要小于等于HAVE_CURRENT_DATA,paused属性为false

应用示例:

 
myVid=document.getElementById("video1");
 
myVid.onwaiting=alert("等待接下来的数据");

此外还可以在标签中定义使用,例如:

 
<audio|video onwaiting="SomeJavaScriptCode">

采用addEventListener()添加事件处理方式:

 
audio|video.addEventListener("waiting", function(){
 
//SomeJavaScriptCode
 
}
 
);
posted on 2017-07-28 15:32  DoubleLi  阅读(592)  评论(0编辑  收藏  举报