play()失败,因为用户没有先与文档进行交互-使用Vimeo API的单击事件

问题描述 投票:3回答:2

我假设一个onclick事件被视为与文档交互,所以不确定为什么会引发自动播放错误

未捕获(承诺)NotAllowedError:play()失败,因为用户未首先与文档进行交互。

const playbtn = document.getElementById('playbtn');
const player = document.getElementById('video-player');
const vimeoPlayer = new Vimeo.Player(player);
playbtn.onclick = function() {
  playbtn.style.display = "none";
  vimeoPlayer.play();
}
vimeoPlayer.on('pause', function() {
  playbtn.style.display = "block";
});
vimeoPlayer.on('play', function() {
  playbtn.style.display = "none";
});
i {
  position: absolute;
  color: white;
}
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.7.2/css/all.css" integrity="sha384-fnmOCqbTlWIlj8LyTjo7mOUStjsKC4pOpQbqyi7RrhN7udi9RwhKkMHpvLbHG9Sr" crossorigin="anonymous">
<script src="https://player.vimeo.com/api/player.js"></script>

<div id="video-outer-full">
  <div id="video-inner">
    <i class="far fa-play-circle" id="playbtn"></i>
    <iframe id="video-player" class="video" width="560" height="315" src="https://player.vimeo.com/video/309741585" frameborder="0" webkitallowfullscreen mozallowfullscreen allowfullscreen></iframe>
  </div>
</div>
javascript vimeo
2个回答
9
投票

我在iframe的属性中缺少allow =“ autoplay”


2
投票

第一个错误是应该为vimeoPlayer.play();您忘记了第一个代码第5行中的",这是第二个错误。然后我尝试了代码,它可以工作。但我不明白为什么会收到此错误消息。

© www.soinside.com 2019 - 2024. All rights reserved.