Detect when an iframe starts to load new URL

前端 未结 4 1914
孤街浪徒
孤街浪徒 2021-01-31 02:07

How can I detect that an iframe on my page starts to load a new page?

Our situation is:

  • When iFrame content starts to change we need to di
相关标签:
4条回答
  • 2021-01-31 02:41

    When you are creating the iframe dynamically, include the ONLOAD event like so...

    F=document.createElement('iframe');
    F.onload=function(){
        UpdateDetails(
            this.contentWindow.document.title,
            this.contentWindow.location
        );
    };
    F.src='some url';
    document.getElementById('Some_Container').appendChild(F);
    

    The onload event will now constantly update the global variables below via the function below, as the user surfs the net:

    var The_Latest_Title='';
    var The_Latest_URL='';
    function UpdateDetails(Title,URL){
        The_Latest_Title=Title;
        The_Latest_URL=URL;
    }
    
    0 讨论(0)
  • 2021-01-31 02:45

    I found a better solution if iframe and the container page is same origin, don't have to put extra code into the inner page:

    <iframe src="same-origin.com" onload="content_finished_loading(this)"></iframe>
    <script>
        var indicator = document.querySelector('.loading-indicator');
        var content_start_loading = function() {
            indicator.style.display = 'block';
        };
    
        var content_finished_loading = function(iframe) {
            indicator.style.display = 'none';
            // inject the start loading handler when content finished loading
            iframe.contentWindow.onunload = content_start_loading;
        };
    </script>
    
    0 讨论(0)
  • 2021-01-31 02:46

    There is already a possible solution at: iFrame src change event detection?

    However, if you want to manipulate the target page, then it is not needed to touch the iframe-target file content. Just add the correct JS code in parent page and it can access SAME-ORIGIN iframe. I used something like this:

    <iframe id="xyz" ....>
    .....
    <script>
    var iframeElement = document.getElementById("xyz");
    var iframe_El = iframeElement.contentDocument || iframeElement.contentWindow.document;
    // manipulate iframe_El wih "on complete" events and like that.
    ....
    </script>
    

    more at: https://jsfiddle.net/Lnb1stc8/

    0 讨论(0)
  • 2021-01-31 02:55

    I came up with following solution - which is only possible because we control the content of the iframe content and the host-window

    Inside the iframe we add following script to the page footer (all pages use the same template, so this is a change to a single file)

    <script>
    window.onunload = function() {
        // Notify top window of the unload event
        window.top.postMessage('iframe_change', '*');
    };
    </script>
    

    Inside the host-window we add this script to monitor the iframe state

    function init_content_monitor() {
        var content = jQuery('.iframe');
    
        // The user did navigate away from the currently displayed iframe page. Show an animation
        var content_start_loading = function() {
            alert ('NOW: show the animation');
        }
    
        // the iframe is done loading a new page. Hide the animation again
        var content_finished_loading = function() {
            alert ('DONE: hide the animation');
        }
    
        // Listen to messages sent from the content iframe
        var receiveMessage = function receiveMessage(e){
            var url = window.location.href,
                url_parts = url.split("/"),
                allowed = url_parts[0] + "//" + url_parts[2];
    
            // Only react to messages from same domain as current document
            if (e.origin !== allowed) return;
            // Handle the message
            switch (e.data) {
                case 'iframe_change': content_start_loading(); break;
            }
        };
        window.addEventListener("message", receiveMessage, false);
    
        // This will be triggered when the iframe is completely loaded
        content.on('load', content_finished_loading);
    }
    
    0 讨论(0)
提交回复
热议问题