html5 实现视频播放

常用属性

  • controls: 显示默认的播放控制条。
  • autoplay: 页面加载时自动播放视频。
  • loop: 视频播放结束后自动重新播放。
  • muted: 静音播放视频。
  • poster: 在视频加载前显示的预览图。

例子:

html 复制代码
<video src="my_video_file.mp4" controls autoplay loop muted poster="review.jpg"></video>

一、实现视频循环播放:

loop属性确保视频循环播放

autoplay属性使视频在页面加载时自动播放

muted属性则静音播放,避免自动播放视频时的声音干扰

html 复制代码
<video class="video_box" loop autoplay muted>
	<source src="my_video_file.mp4" type="video/mp4">
	<span>This video browser does not support</span>
</video>

二、使用JavaScript控制视频播放

1、通过监听视频的ended事件,在视频播放结束时重新播放

html 复制代码
<video id="myVideo">
	<source src="my_video_file.mp4" type="video/mp4">
	<span>This video browser does not support</span>
</video>
<script>
	const myVideo = document.getElementById('myVideo');
	myVideo.addEventListener('ended', () => {
	  myVideo.play();
	});
</script>

2、通过检查视频的currentTime属性,实现更精细的控制

html 复制代码
<video id="myVideo">
	<source src="my_video_file.mp4" type="video/mp4">
	<span>This video browser does not support</span>
</video>
<script>
	const myVideo = document.getElementById('myVideo');
	myVideo.addEventListener('timeupdate', () => {
		if (myVideo.currentTime >= myVideo.duration - 0.2) {
			myVideo.currentTime = 0;
			myVideo.play();
		}
	});
</script>

三、css动画加JavaScript控制视频效果

html 复制代码
<style>
	.video_fade_in {animation: fadeIn 2s;}
	.video_fade_out {animation: fadeOut 2s;}
	@keyframes fadeIn {from { opacity: 0; }to { opacity: 1; }}	
	@keyframes fadeOut {from { opacity: 1; }to { opacity: 0; }}
</style>
<video class="video_fade_in">
	<source src="my_video_file.mp4" type="video/mp4">
	<span>This video browser does not support</span>
</video>
<video id="myVideo" class="video_fade_out">
	<source src="my_video_file.mp4" type="video/mp4">
	<span>This video browser does not support</span>
</video>
<!-- 在视频播放结束后淡入淡出 -->
<script>
	const myVideo = document.getElementById('myVideo');
	myVideo.addEventListener('ended', () => {
	  myVideo.classList.add('video_fade_out');
	  setTimeout(() => {
	    myVideo.classList.remove('video_fade_out');
	    myVideo.currentTime = 0;
	    myVideo.play();
	  }, 2000);
	});
</script>
相关推荐
小声读源码27 分钟前
【技巧】dify前端源代码修改第一弹-增加tab页
前端·pnpm·next.js·dify
假客套36 分钟前
2025 后端自学UNIAPP【项目实战:旅游项目】7、景点详情页面【完结】
前端·uni-app·旅游
Captaincc1 小时前
Ilya 现身多大毕业演讲:AI 会完成我们能做的一切
前端·ai编程
teeeeeeemo1 小时前
Vue数据响应式原理解析
前端·javascript·vue.js·笔记·前端框架·vue
Sahas10191 小时前
__VUE_PROD_HYDRATION_MISMATCH_DETAILS__ is not explicitly defined.
前端·javascript·vue.js
Jinxiansen02111 小时前
Vue 3 实战:【加强版】公司通知推送(WebSocket + token 校验 + 心跳机制)
前端·javascript·vue.js·websocket·typescript
MrSkye1 小时前
React入门:组件化思想?数据驱动?
前端·react.js·面试
BillKu1 小时前
Java解析前端传来的Unix时间戳
java·前端·unix
@Mr_LiuYang1 小时前
网页版便签应用开发:HTML5本地存储与拖拽交互实践
前端·交互·html5·html5便签应用
JacksonGao2 小时前
一分钟带你了解React Fiber的工作单元结构!
前端·react.js