HTML5怎么循环播放视频_让视频播完自动重播的代码写法【教程】

发布时间 - 2026-01-04 00:00:00    点击率:
直接加 loop 属性即可实现视频循环播放,它是 HTML5 原生布尔属性,存在即生效,无需赋值;需确保视频加载成功、未被 pause 中断、避免 preload="none" 影响,并注意移动端需配合 muted 使用 autoplay。

直接加 loop 属性就行,不需要 JavaScript。

HTML5 标签的 loop 属性怎么用

这是原生支持的布尔属性,只要存在就生效,无需赋值。浏览器会自动在视频末尾跳回开头并继续播放。

  • loop 是标准 HTML5 属性,所有现代浏览器(Chrome、Firefox、Safari、Edge)都支持
  • 不要写成 loop="true"loop="loop" —— 这样虽然多数情况下也生效,但不符合规范,且在某些严格解析环境(如部分 SSR 场景)可能被忽略
  • 它和 autoplay 可以共存,但注意:Safari 和新版 Chrome 对静音自动播放有策略限制,autoplay 单独使用可能被拦截

为什么加了 loop 还不重播?常见原因

不是属性写错了,而是被其他行为或设置覆盖了。

  • 视频加载失败(src 路径错误、MIME 类型不匹配、跨域限制)→ 浏览器根本没加载成功,自然不会触发循环逻辑
  • 手动调用了 video.pause() 或监听了 ended 事件后执行了 video.currentTime = 0 却忘了 video.play() → 此时 loop 已失效,因为播放已中断
  • 设置了 preload="none" 且用户未手动点击播放 → 视频未预加载,loop 在首次播放完成前无意义
  • 移动端 Safari 对 loop + autoplay 的组合支持不稳定,尤其未静音时,建议搭配 muted 使用

需要 JS 控制循环时该怎么做(比如加延迟、换素材、统计次数)

如果只是循环播放,别用 JS;但如果要干预行为(比如播完等 1 秒再重播,或切换不同视频),就得监听 ended 事件。

  • ended 事件只在自然播放结束时触发(非用户暂停/拖拽导致),比轮询 currentTime 更可靠
  • 手动重播必须显式调用 play(),否则只重置时间但不播放(尤其在移动设备上)
  • 注意 Promise 返回值:现代浏览器中 play() 可能返回 Promise,需处理拒绝(如用户手势未触发、音频未静音)
const video = document.querySelector('video');
video.addEventListener('ended', () => {
  video.currentTime = 0;
  video.play().catch(e => console.warn('Auto-replay failed:', e));
});

真正容易被忽略的是:当视频源动态变更(比如通过 JS 修改 src)后,loop 属性依然有效,但浏览器会重新加载——此时如果网络慢或资源大,可能出现“黑屏卡顿”,而不是无缝循环。这种场景下,用 ended + loadstart 状态管理更可控。


# javascript  # java  # html  # js  # html5  # 浏览器  # edge  # safari  # ai  # 跨域  # 为什么 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Android中AutoCompleteTextView自动提示  Laravel如何实现一对一模型关联?(Eloquent示例)  实现点击下箭头变上箭头来回切换的两种方法【推荐】  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  如何选择可靠的免备案建站服务器?  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  如何在Windows 2008云服务器安全搭建网站?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  如何在香港免费服务器上快速搭建网站?  如何确保FTP站点访问权限与数据传输安全?  Laravel如何实现模型的全局作用域?(Global Scope示例)  如何自定义建站之星模板颜色并下载新样式?  如何在建站之星网店版论坛获取技术支持?  在线制作视频网站免费,都有哪些好的动漫网站?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  Laravel怎么实现验证码(Captcha)功能  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复  javascript日期怎么处理_如何格式化输出  网站建设要注意的标准 促进网站用户好感度!  Android自定义控件实现温度旋转按钮效果  LinuxCD持续部署教程_自动发布与回滚机制  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  怎么用AI帮你设计一套个性化的手机App图标?  如何快速配置高效服务器建站软件?  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  微信推文制作网站有哪些,怎么做微信推文,急?  如何快速搭建自助建站会员专属系统?  Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践  jquery插件bootstrapValidator表单验证详解  WEB开发之注册页面验证码倒计时代码的实现  Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程  Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】  如何挑选高效建站主机与优质域名?  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  如何快速搭建高效可靠的建站解决方案?  Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  Laravel如何使用Blade模板引擎?(完整语法和示例)  北京网站制作公司哪家好一点,北京租房网站有哪些?  大同网页,大同瑞慈医院官网?  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  ,网页ppt怎么弄成自己的ppt?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议  Laravel怎么导出Excel文件_Laravel Excel插件使用教程  javascript如何操作浏览器历史记录_怎样实现无刷新导航