preload
默认情况下我们实现一个简单的 H5 的播放器,只需要这么简单的代码就好:
<video preload width="320" height="240" controls src="./static/videos/1.mp4"></video>
这个时候用户点击播放按钮就可以开始播放了。
但是为了更好的用户体验,我们有的时候需要预加载视频,比如有的视频可能是在用户产生某些交互进行显示播放的。这个时候我们优先想到的是 preload 属性。
此属性用于定义视频是否预加载。属性有三个可选择的值:none
、metadata
、auto
。如果不使用此属性,默认为auto。
- None:不进行预加载。使用此属性值,可能是页面制作者认为用户不期望此视频,或者减少HTTP请求。
- Metadata:部分预加载。使用此属性值,代表页面制作者认为用户不期望此视频,但为用户提供一些元数据(包括尺寸,第一帧,曲目列表,持续时间等等)。
- Auto:全部预加载。
但是我们查看视频的请求,我们发现其实只预加载了一部分。它并没有自动进行全部视频内容的下载,这样的策略实际有利于节约用户宽带造成不必要的请求。
video 提供了 包括 play , pause , progress 等事件。当播放器处在不同的状态时候进行触发。其中 progress 会在视频进行下载的时候进行触发。
video.addEventListener("progress", function() {
// When buffer is 1 whole video is buffered
if (Math.round(video.buffered.end(0)) / Math.round(video.seekable.end(0