首页 > 其他分享 >DOMException - play() 请求中断

DOMException - play() 请求中断

时间:2024-01-05 22:11:07浏览次数:33  
标签:视频 play DOMException 中断 pause promise video 播放

DOMException - play() 请求中断

 

 

弗朗索瓦·博福 François Beaufort GitHub

 

您刚才在 Chrome 开发者工具 JavaScript 控制台中发现了这个意外的媒体错误吗?

注意 :未捕获(承诺中)DOMException:play() 请求因调用 pause() 而中断。

注意未捕获(在承诺中)DOMException:play() 请求被新的加载请求中断。

那你来对地方了。别担心,我会说明导致此问题的原因以及解决方法

导致此错误的原因

下面的一些 JavaScript 代码可重现您所看到的“Uncaught (in promise)”(未捕获)错误:

错误做法  
<video id="video" preload="none" src="https://example.com/file.mp4"></video>

<script>
  video.play(); // <-- This is asynchronous!
  video.pause();
</script>

上面的代码会在 Chrome 开发者工具中导致以下错误消息:

_Uncaught (in promise) DOMException: The play() request was interrupted by a call to pause().

由于视频因 preload="none" 而未加载,因此视频播放不一定在执行 video.play() 后立即开始播放。

此外,自 Chrome 50 起,对 <video> 或 <audio> 元素的 play() 调用会返回一个 Promise,这是一个异步返回单个结果的函数。如果播放成功,系统会执行 promise 并同时触发 playing 事件。如果播放失败,promise 将被拒绝,并提供一条说明失败的错误消息。

现在会发生以下情况:

  1. video.play() 开始异步加载视频内容。
  2. video.pause() 会中断视频加载,因为它尚未准备就绪。
  3. video.play() 以异步方式大声拒绝。

由于我们在代码中未处理视频播放 Promise,因此 Chrome 开发者工具中显示一条错误消息。

注意 :调用 video.pause() 并不是中断视频的唯一方式。您可以使用 video.load() 和 video.src = '' 完全重置视频播放状态,包括缓冲区。

解决方法

了解了根本原因之后,我们来看看如何解决此问题。

首先,不要假设系统会播放媒体元素(视频或音频)。查看 play 函数返回的 Promise,以查看其是否被拒绝。值得注意的是,Promise 只有在播放实际开始播放后才会执行,这意味着 then() 中的代码只有在媒体开始播放后才会执行。

正确做法

示例:自动播放

 
<video id="video" preload="none" src="https://example.com/file.mp4"></video>

<script>
  // Show loading animation.
  var playPromise = video.play();

  if (playPromise !== undefined) {
    playPromise.then(_ => {
      // Automatic playback started!
      // Show playing UI.
    })
    .catch(error => {
      // Auto-play was prevented
      // Show paused UI.
    });
  }
</script>
正确做法

示例:播放和暂停

 
<video id="video" preload="none" src="https://example.com/file.mp4"></video>
 
<script>
  // Show loading animation.
  var playPromise = video.play();
 
  if (playPromise !== undefined) {
    playPromise.then(_ => {
      // Automatic playback started!
      // Show playing UI.
      // We can now safely pause video...
      video.pause();
    })
    .catch(error => {
      // Auto-play was prevented
      // Show paused UI.
    });
  }
</script>

这个简单示例非常好用,但如果您之后能够使用 video.play() 播放视频,该怎么办呢?

我告诉你一个秘密。您不必使用 video.play(),也可以使用 video.load(),方法如下:

正确做法

示例:提取并播放

 
<video id="video"></video>
<button id="button"></button>

<script>
  button.addEventListener('click', onButtonClick);

  function onButtonClick() {
    // This will allow us to play video later...
    video.load();
    fetchVideoAndPlay();
  }

  function fetchVideoAndPlay() {
    fetch('https://example.com/file.mp4')
    .then(response => response.blob())
    .then(blob => {
      video.srcObject = blob;
      return video.play();
    })
    .then(_ => {
      // Video playback started ;)
    })
    .catch(e => {
      // Video playback failed ;(
    })
  }
</script>
警告:请勿将 onButtonClick 函数与 async 关键字异步。您将失去稍后播放视频所需的“用户手势令牌”。

Play promise 支持

在写入时,HTMLMediaElement.play() 会在 Chrome、Edge、Firefox、Opera 和 Safari 中返回一个 promise。

危险区域

<video> 中的 <source> 使 play() promise 永不拒绝

对于 <video src="not-existing-video.mp4"\>play() promise 会按预期拒绝,因为视频不存在。对于 <video><source src="not-existing-video.mp4" type='video/mp4'></video>play() promise 绝不会拒绝。仅当没有有效来源时,才会出现这种情况。

Chromium 错误

该内容对您有帮助吗?

标签:视频,play,DOMException,中断,pause,promise,video,播放
From: https://www.cnblogs.com/sexintercourse/p/17948202

相关文章

  • 大模型训练中断,断点续传助力快速恢复
    深度学习在计算机视觉领域的地位日益显著,其中,YOLOv5(YouOnlyLookOnceversion5)模型因其高效和准确而受到广泛关注。但在实际训练过程中,由于数据集大小、计算资源或意外中断等原因,训练可能会突然中断。这时,如何恢复训练并确保之前的工作不白费,就显得尤为重要。而“断点续传”这一......
  • 荷兰半导体设备供应商在美政府压力下中断向中国发货 | 百能云芯
    据报道,在荷兰新的高阶芯片制造设备出口限制禁令1月全面生效之前,荷兰半导体制造设备供应商ASML已经响应美国政府要求,取消了向中国的部分设备发货。根据ASML官方声明,荷兰政府已经取消了NXT:2050i和NXT:2100i的部分出口许可,影响到了少数中国客户。公司表示,这一举措不会对其财务前景......
  • netty源码:(40)ReplayingDecoder
    ReplayingDecoder是ByteToMessageDecoder的子类,我们继承这个类时,也要实现decode方法,示例如下:packagecn.edu.tju;importio.netty.buffer.ByteBuf;importio.netty.channel.ChannelHandlerContext;importio.netty.handler.codec.ReplayingDecoder;importjava.nio.charset.C......
  • 07PCIE数据卡BRAM缓存中断采集
    软件版本:vitis2021.1(vivado2021.1)操作系统:WIN1064bit硬件平台:适用XILINXA7/K7/Z7/ZU/KU系列FPGA登录"米联客"FPGA社区-www.uisrc.com视频课程、答疑解惑!7.1概述在方案中,使用基于AXI4实现的FDMA来实现数据的缓存。通过切换缓存的地址,实现2帧以上缓存数据的读取。这种构架......
  • 08PCIE数据卡DDR缓存中断采集
    软件版本:vitis2021.1(vivado2021.1)操作系统:WIN1064bit硬件平台:适用XILINXA7/K7/Z7/ZU/KU系列FPGA登录"米联客"FPGA社区-www.uisrc.com视频课程、答疑解惑!8.1概述上一个例子演示了用BRAM作为数据缓存,显然板卡的BRAM容量非常有限,如果需要更大量数据的缓存就得用到DDR作为缓......
  • flutter ios swift avplayer 播放器自动播放下一集
    使用监听监听结束事件importFoundationimportAVKitimportMediaPlayerimportFlutterclassFlutterAVPlayerView:NSObject,FlutterPlatformView{privatevar_flutterAVPlayerViewController:AVPlayerViewControllerprivatevarurlArray:[URL]=[]......
  • Linux驱动开发之Linux内核中的中断处理以及相关API和例程分析
    中断是计算机中实现异步事件处理的一种关键机制。当中断发生时,CPU会暂停当前的任务,转去运行中断服务例程。中断处理完成后,CPU再返回到原来的任务。这使得中断处理具有很高的实时性和响应速度。在Linux内核中,充分利用了中断机制来响应各种硬件和软件事件。在Linux操作系统中,中断......
  • 初中英语优秀范文100篇-042Is It Good for Students to Play Video Games?学生玩游戏
    PDF格式公众号回复关键字:SHCZFW042记忆树1Videogameshavebecomemoreandmorepopularnow.翻译现在视频游戏变得越来越流行。简化记忆流行句子结构1主语(Subject):"Videogames"(电子游戏)是句子的主题,表示现在完成时态的承受者。2谓语(Predicate):"havebe......
  • fetch 请求 stream 流接口并使用 AbortController 中断结果响应
    1.使用fetch请求stream流接口:封装fetch工具方法fetchRequest.jsconstfetchStream=async(url,options)=>{constresponse=awaitfetch(url,options);if(response.status!==200){returnfalse;}constreader=response.body.getReader();ret......
  • 31.Playwright 自动化测试框架
    Playwright简介 Playwright官网:https://playwright.dev/python/docs/introWeb自动化测试框架。跨平台多语言支持。支持Chromium、Firefox、WebKit等主流浏览器自动化操作。Playwright的优点 支持所有流行的浏览器。速度更快,更可靠的执行。更强大的......