设置html5 的video 当前播放时间

原文: http://blog.csdn.net/renfufei/article/details/44522887

上周翻译了一篇文章: 如何获取HTML5视频的持续时间。很显然这是一门简单却很实用的技术, 但我认为还有一个更重要的知识点是控制视频的时间设置。在用HTML5技术处理视频时,设置(setting)和获取(getting)时间都是很有用的,那就让我们一起来看看如何达成这个 目标吧!

在管理视频状态时,最重要的是要了解 currentTime 是个什么鬼。你可以通过这个属性获取当前播放到了哪个时间点:

// https://www.youtube.com/watch?v=Cwkej79U3ek
console.log(video.currentTime);  // 25.431747

currentTime 既是 getter 又是 setter 属性, 所以可以直接设置 currentTime 值来控制播放进度:

video.currentTime = 0; // Restart

API 接口很容易理解,而且是自解释的(self-explanatory)。你仍然需要处理“second”来指定时间,包括内在实际的和外在显示的(both inward and outward),但是秒(second)这个单位和你预期的一样公平,所以说这个API设计是非常巧妙的。

示例可以参考 小米空气净化器的演示页面: http://www.mi.com/air/

<video id="videoIntro" class="video" 
    data-video-name="intro" 
    poster="http://c1.mifile.cn/f/i/2014/cn/goods/air/overall/video-main-poster.jpg"
    style="height: 600px; width: 800px; display: none;">
        <source type="video/mp4" 
    src="http://c1.mifile.cn/f/i/2014/cn/goods/air/overall/video-intro.mp4?2014120901">
        <source type="video/webm"
    src="http://c1.mifile.cn/f/i/2014/cn/goods/air/overall/video-intro.webm?2014120901">
</video>

此外,苹果官网的演示也采用这样的控制模式。

原文链接: http://davidwalsh.name/html5-video-current-time

原文日期: 2015年03月16日

翻译日期: 2015年03月21日

翻译人员: 铁锚 http://blog.csdn.net/renfufei

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTML5video标签提供了断点播放的功能,即当视频暂停后再次播放时能够从暂停的位置继续播放。 要实现断点播放,首先需要获取到视频的当前播放时间,可以使用video元素的currentTime属性来获取。在用户点击暂停按钮或视频播放结束时,可以将当前播放时间保存到本地存储(比如Cookie、LocalStorage或SessionStorage)中。 当用户再次打开页面或重新加载页面时,可以先检查本地存储中是否存在已保存的播放时间。如果存在则可以通过JavaScript将视频的currentTime设置为保存的播放时间,然后调用play方法来继续播放视频。 以下是一个简单的示例代码: ```html <!DOCTYPE html> <html> <body> <video id="my-video" width="320" height="240"> <source src="video.mp4" type="video/mp4"> </video> <button onclick="pauseVideo()">暂停</button> <button onclick="resumeVideo()">继续播放</button> <script> var video = document.getElementById("my-video"); function pauseVideo() { // 暂停视频并保存当前播放时间 video.pause(); localStorage.setItem("playbackPosition", video.currentTime); } function resumeVideo() { // 检查是否有保存的播放时间,并继续播放视频 var playbackPosition = localStorage.getItem("playbackPosition"); if (playbackPosition) { video.currentTime = playbackPosition; video.play(); } } </script> </body> </html> ``` 上述代码中,当用户点击“暂停”按钮时,会调用pauseVideo函数,其中通过video.pause()暂停视频播放,并使用localStorage.setItem将当前播放时间保存到本地存储中。 当用户点击“继续播放”按钮时,会调用resumeVideo函数,其中通过localStorage.getItem获取保存的播放时间,并使用video.currentTime设置视频的当前播放时间,最后调用video.play()来继续播放视频。 这样,用户就可以从之前暂停的位置继续播放视频。当然,你也可以根据实际需求使用其他的本地存储方式来保存播放时间

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值