HTML5的video标签

如今若是要在页面中使用video标签,须要考虑三种状况,支持Ogg Theora或者VP8(若是这玩意儿没出事的话)的(Opera、Mozilla、Chrome),支持H.264的(Safari、IE 九、Chrome),都不支持的(IE六、七、8)。好吧,如今让咱们从技术层面来认识HTML 5的视频,包括video标签的使用,视频对象能够用到的媒介属性和方法,以及媒介事件。html

Video标签的使用浏览器

Video标签含有src、poster、preload、autoplay、loop、controls、width、height等几个属性, 以及一个内部使用的标签<source>。Video标签内除了能够包含<source>标签外,还能够包含当指定的视频都不能播放时,返回的内容。ide

(1) src属性和poster属性oop

你能想象src属性是用来干啥的。跟<img>标签的同样,这个属性用于指定视频的地址。而poster属性用于指定一张图片,在当前视频数据无效时显示(预览图)。视频数据无效多是视频正在加载,多是视频地址错误等等。post

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay"></video>

(2) preload属性编码

这个属性也能经过名字了解用处,此属性用于定义视频是否预加载。属性有三个可选择的值:none、metadata、auto。若是不使用此属性,默认为auto。spa

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none"></video>

None:不进行预加载。使用此属性值,多是页面制做者认为用户不指望此视频,或者减小HTTP请求。code

Metadata:部分预加载。使用此属性值,表明页面制做者认为用户不指望此视频,但为用户提供一些元数据(包括尺寸,第一帧,曲目列表,持续时间等等)。视频

Auto:所有预加载。htm

(3) autoplay属性

又是一个看名字知道用处的属性。Autoplay属性用于设置视频是否自动播放,是一个布尔属性。当出现时,表示自动播放,去掉是表示不自动播放。

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none"></video>

注意,HTML中布尔属性的值不是true和false。正确的用法是,在标签中使用此属性表示true,此时属性要么没有值,要么其值恒等于他的名字 (此处,自动播放为<video autoplay />或者<video autoplay=”autoplay” />);而在标签中不使用此属性表示false(此处不进行自动播放为<video />)。

 (4) loop属性

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay" loop="loop"></video>

一目了然,loop属性用于指定视频是否循环播放,一样是一个布尔属性。

(5) controls属性

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none" controls="controls"></video>

Controls属性用于向浏览器指明页面制做者没有使用脚本生成播放控制器,须要浏览器启用自己的播放控制栏。

控制栏须包括播放暂停控制,播放进度控制,音量控制等等。

每一个浏览器默认的播放控制栏在界面上不同。因为我浏览器的诡异问题,Firefox和Safari的Video标签不正常,因此这两个只能在网上找截图了。

(6) width属性和height属性

属于标签的通用属性了,这个不用多说。

(7) source标签

<video width="658" height="444" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none" controls="controls"><source src="http://www.youname.com/images/first.ogv" /><source src="http://www.youname.com/images/first.ogg" /></video>


浏览器按source标签的顺序检测标签指定的视频是否可以播放(多是视频格式不支持,视频不存在等等),若是不能播放,换下一个。此方法多用于兼容不一样的浏览器。Source标签自己不表明任何含义,不能单独出现。Source标签用于给媒体(由于audio标签一样能够包含此标签,因此这儿用媒体,而不是视频)指定多个可选择的(浏览器最终只能选一个)文件地址,且只能在媒体标签没有使用src属性时使用。

此标签包含src、type、media三个属性。

src属性:用于指定媒体的地址,和video标签的同样。

Type属性:用于说明src属性指定媒体的类型,帮助浏览器在获取媒体前判断是否支持此类别的媒体格式。

Media属性:用于说明媒体在何种媒介中使用,不设置时默认值为all,表示支持全部媒介。你想到<style>标签的media属性了么?同样同样同样的。

(8) 一个完整的例子

<video width="658" height="444" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none" controls="controls"><source src="http://www.youname.com/images/first.ogv" /><source src="http://www.youname.com/images/first.ogg" /></video>

这段代码在页面中定义了一个视频,此视频的预览图为poster的属性值,显示浏览器的默认媒体控制栏,预加载视频的元数据,循环播放,宽度为900像素,高度为240像素。

第一选择视频地址为第一个source标签的src属性值,视频类别为Ogg视频,视频编码译码器为Theora,音频编码译码器为Vorbis,播放媒 介为显示器;第二选择视频地址再也不累述。若是你还要兼容IE的话,能够在最后一个source标签后再加上Flash播放器的标签集,或者使用一点 JavaScript代码。

相关文章
相关标签/搜索