2016-05-08 6 views
1

Wenn ich in HTML mit AJAX lade, wie kann ich überprüfen, ob alle Bilder in diesem HTML vollständig geladen sind, bevor "etwas" (wie angezeigt).Überprüfen Sie, dass alle AJAX-Bilder zuerst geladen werden

Ich habe eine Auswahl von Möglichkeiten, einschließlich der "Bilder geladen" Plugin.

var page = 'P40', 
    path = 'http://www.domain.com/gallery/embed-items/'+page; 

$.get(path, function(data) { 

    $(data).imagesLoaded(function() { 

    $('#gallery-masonry').append($.parseHTML(data)); 

     $galleryContainer.masonry("reloadItems"); 
     $galleryContainer.masonry(); 

    }); 

}); 

Der HTML-Code, in 'data' gesetzt wird, ist etwa 20 wie folgt aus:

<div class="grid col-12 bp1-col-6 bp2-col-4 bp3-col-3 item gallery-item half-divide"> 

    <img srcset="http://www.domain.com/images/uploads/gallery/Venice_Lagoon_Sunrise_2_Jan_2016-1550.jpg, http://www.domain.com/images/uploads/gallery/Venice_Lagoon_Sunrise_2_Jan_2016-1550.jpg 2x" title="Venice Lagoon Sunrise" alt="Venice Lagoon Sunrise"> 

</div> 

NEW

$.get(path, function(data) { 

    var doc = document.implementation.createHTMLDocument(""); // you could also use DOMParser, but parsing HTML is supported only in modern browsers. 
    doc.body.innerHTML = data; // write the data to document 

    var images = doc.querySelectorAll("img"), // get all images, you can specify only some though by particular selector 
     amount = images.length; // inital length 

    [].forEach.call(images, function(img) { // loop over images 
     img.onload = function() { // bind the listener 

      amount--; // ok one item was loaded, we decrease the amount 

      if (amount === 0) { // if amount is equal to 0, it means the images are loaded 

       $('#gallery-masonry').append(body); 

       $galleryContainer.masonry("reloadItems"); 
       $galleryContainer.masonry(); 

      } 

     }; 

    }); 

    var body = $('body')[0].appendParent(doc.querySelector("body")); // attach the content of body (the data you received). 

}); 

Antwort

1

Es ist ein Ereignis ausgelöst, wenn das Bild geladen ist - es ist "Laden" genannt. Sie können es verwenden und es an alle Bilder anhängen, die Sie erhalten. Sie sollten diesen Ereignis-Listener binden, bevor die Bilder dem DOM hinzugefügt werden (dh bevor der Download noch nicht ausgeführt wird).

Beispiel:

var page = 'P40', 
path = '/'; 

$.get(path, function(data) { 
    var doc = document.implementation.createHTMLDocument(""); // you could also use DOMParser, but parsing HTML is supported only in modern browsers. 
    doc.body.innerHTML = data; // write the data to document 

    var images = doc.querySelectorAll("img"), // get all images, you can specify only some though by particular selector 
     amount = images.length; // inital length 

    [].forEach.call(images, function(img) { // loop over images 
    img.onload = function() { // bind the listener 
     amount--; // ok one item was loaded, we decrease the amount 
     if (amount === 0) { // if amount is equal to 0, it means the images are loaded 
     // images loaded 
     } 
    }; 
    }); 

// loop over the content of body (it wraps your content) and add each child of it 
    [].forEach.call(doc.body.children, function(child) { 
    document.body.appendChild(child); 
    }); 
}); 

Rework des Codes

$.get(path, function(data) { 
    var container = $('#gallery-masonry')[0]; // container for images 

    var doc = document.implementation.createHTMLDocument(""); // you could also use DOMParser, but parsing HTML is supported only in modern browsers. 
    doc.body.innerHTML = data; // write the data to document 

    var images = doc.querySelectorAll("img"), // get all images, you can specify only some though by particular selector 
     amount = images.length; // inital length 

    [].forEach.call(images, function(img) { // loop over images 
     img.onload = function() { // bind the listener 

      amount--; // ok one item was loaded, we decrease the amount 

      if (amount === 0) { // if amount is equal to 0, it means the images are loaded  
       container.style.display = ""; 
       $galleryContainer.masonry("reloadItems"); 
       $galleryContainer.masonry(); 

      } 

     }; 

    }); 

    container.style.display = "none"; 
    [].forEach.call(doc.body.children, function(child) { 
     container.appendChild(child); 
    }); 

}); 
+0

Sie Jakub Dank. Ich habe Ihren Code durchgesehen, um zu verstehen, wie er funktioniert. Ich habe einen "NEUEN" Code in meine Frage eingefügt. Ich füge die geladenen Daten in ein anderes div ein. Wie es aussieht, fügt es die Daten hinzu, die in "Körper" eingewickelt sind. Gibt es eine Möglichkeit, die Daten zu laden und sie ohne die Umhüllung von 'Körper' anzuhängen? – ccdavies

+0

@ccdavies, es war eigentlich mein schlechtes. Ich habe gerade den Code aktualisiert. Im Grunde müssen Sie die Kinder des Bodies überschleifen und jedes davon an den Dokumentkörper Ihres Dokuments anhängen. –

+0

Danke, aber ich bin mir immer noch nicht sicher, wie ich das dann an meinen "NEUEN" Code anhängen würde. Ich habe versucht, den geänderten Code als Variable hinzuzufügen, aber das funktioniert nicht. – ccdavies