0

我有一个使用 Player api ( http://www.dailymotion.com/doc/api/player.html ) 的 Dailymotion 嵌入式播放器。它适用于台式机和 Android 平板电脑。但在 iOS 设备上,视频无法启动。我的代码如下:

<!-- This <div> tag will be replaced the <iframe> video player -->
<div id="player"></div>

<script>
    // This code loads the Dailymotion Javascript SDK asynchronously.
    (function() {
        var e = document.createElement('script'); e.async = true;
        e.src = document.location.protocol + '//api.dmcdn.net/all.js';
        var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(e, s);
    }());

    // This function init the player once the SDK is loaded
    window.dmAsyncInit = function()
    {
        // PARAMS is a javascript object containing parameters to pass to the player if any (eg: {autoplay: 1})
        var player = DM.player("player", {video: 'somevideoid', width: "100%", height: "100%", params: {autoplay: 0}});

        // 4. We can attach some events on the player (using standard DOM events)
        player.addEventListener("apiready", function(e)
        {
            e.target.play();
        });
    };
</script>
4

1 回答 1

3

您的代码完全有效。问题是大多数移动设备,包括 iOS 设备,都会阻止视频自动播放(请参阅Apple 文档:Safari HTML5 音频和视频指南)。在这些设备上,第一次播放必须由用户交互触发,例如触摸播放按钮,否则浏览器会忽略它。

apiready事件由 Dailymotion SDK 触发,不是用户事件。这就是为什么该play()方法对视频没有影响的原因。

[编辑]:您宁愿play()从另一个事件侦听器(例如 aclicktouchend事件)调用该方法。. 此外,由于 Dailymotion 播放器嵌入在 中,因此无论父页面的原始事件是否来自用户,浏览器始终将<iframe>父页面与 之间的通信<iframe>视为编程事件。

TLDR:在移动设备上,您必须等待用户触摸播放器的开始屏幕。

于 2014-06-27T08:37:44.883 回答