FancyBox and Youtube API events

前端 未结 2 1469
慢半拍i
慢半拍i 2020-12-12 03:57

I\'m trying to fire an event once the youtube video that I\'m playing into my fancybox is ended.

So I can close automatically the fancybox once the video is over.

相关标签:
2条回答
  • 2020-12-12 04:18

    Possible causes:

    • Testing "locally" (loading the file without going through http://localhost)
    • Mixing Embed API (where you declare an iframe) with iframe API (where you declare a DIV and load some JS). The events only seem to work with the latter.
    • ID on the DIV does not match ID on new YT.Player(...) call
    0 讨论(0)
  • 2020-12-12 04:32

    Please see following working code (you should use version 2 of fancybox.)

    jsfiddle: http://jsfiddle.net/c5h9U/2/

    // Fires whenever a player has finished loading
    function onPlayerReady(event) {
        event.target.playVideo();
    }
    
    // Fires when the player's state changes.
    function onPlayerStateChange(event) {
        // Go to the next video after the current one is finished playing
        if (event.data === 0) {
            $.fancybox.close();
        }
    }
    
    // The API will call this function when the page has finished downloading the JavaScript for the player API
    function onYouTubePlayerAPIReady() {
    
        // Initialise the fancyBox after the DOM is loaded
        $(document).ready(function() {
            $(".fancybox")
                .attr('rel', 'gallery')
                .fancybox({
                    openEffect  : 'none',
                    closeEffect : 'none',
                    nextEffect  : 'none',
                    prevEffect  : 'none',
                    padding     : 0,
                    margin      : 50,
                    beforeShow  : function() {
                        // Find the iframe ID
                        var id = $.fancybox.inner.find('iframe').attr('id');
    
                        // Create video player object and add event listeners
                        var player = new YT.Player(id, {
                            events: {
                                'onReady': onPlayerReady,
                                'onStateChange': onPlayerStateChange
                            }
                        });
                    }
                });
        // Launch fancyBox on first element
        $(".fancybox").eq(0).trigger('click');
        });
    
    }
    
    0 讨论(0)
提交回复
热议问题