Асинхронная загрузка изображений с помощью jQuery - PullRequest
137 голосов
/ 26 ноября 2010

Я хочу загрузить внешние изображения на своей странице асинхронно, используя jQuery , и я попробовал следующее:

$.ajax({ 
   url: "http://somedomain.com/image.jpg", 
   timeout:5000,
   success: function() {

   },
   error: function(r,x) {

   }
});

Но всегда возвращается ошибка, возможно ли даже загрузить изображениекак это?

Я пытался использовать метод .load, и он работает, но я не представляю, как установить время ожидания, если изображение недоступно (404).Как я могу это сделать?

Ответы [ 10 ]

194 голосов
/ 26 ноября 2010

Нет необходимости в AJAX. Вы можете создать новый элемент изображения, установить его атрибут источника и поместить его где-нибудь в документе после завершения загрузки:

var img = $("<img />").attr('src', 'http://somedomain.com/image.jpg')
    .on('load', function() {
        if (!this.complete || typeof this.naturalWidth == "undefined" || this.naturalWidth == 0) {
            alert('broken image!');
        } else {
            $("#something").append(img);
        }
    });
74 голосов
/ 03 октября 2012

ЕСЛИ ДЕЙСТВИТЕЛЬНО ВАМ НЕОБХОДИМО ИСПОЛЬЗОВАТЬ AJAX ...

Я натолкнулся на случаи, когда обработчики загрузки не были подходящим выбором. В моем случае при печати через JavaScript. Таким образом, для этого есть два варианта использования стиля AJAX:

Раствор 1

Используйте данные изображения Base64 и сервис изображений REST. Если у вас есть собственный веб-сервис, вы можете добавить сценарий REST JSP / PHP, который предлагает изображения в кодировке Base64. Теперь, как это полезно? Я столкнулся с новым классным синтаксисом кодирования изображений:

<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhE..."/>

Таким образом, вы можете загружать данные Image Base64 с помощью Ajax, а затем по завершении вы строите строку данных Base64 в образ! Большое удовольствие :). Я рекомендую использовать этот сайт http://www.freeformatter.com/base64-encoder.html для кодирования изображений.

$.ajax({ 
    url : 'BASE64_IMAGE_REST_URL', 
    processData : false,
}).always(function(b64data){
    $("#IMAGE_ID").attr("src", "data:image/png;base64,"+b64data);
});

Solution2:

Обманите браузер, чтобы использовать его кеш. Это дает вам хороший fadeIn (), когда ресурс находится в кэше браузера:

var url = 'IMAGE_URL';
$.ajax({ 
    url : url, 
    cache: true,
    processData : false,
}).always(function(){
    $("#IMAGE_ID").attr("src", url).fadeIn();
});   

Однако оба метода имеют свои недостатки: первый работает только в современных браузерах. Второй имеет проблемы с производительностью и полагается на предположение, как будет использоваться кеш.

ура, будет

11 голосов
/ 14 июня 2015

Используя jQuery, вы можете просто изменить атрибут "src" на "data-src". Изображение не будет загружено. Но местоположение хранится с тегом . Который мне нравится.

<img class="loadlater" data-src="path/to/image.ext"/>

Простой кусок jQuery копирует data-src в src, который начнет загрузку изображения, когда вам это нужно В моем случае, когда страница закончила загрузку.

$(document).ready(function(){
    $(".loadlater").each(function(index, element){
        $(element).attr("src", $(element).attr("data-src"));
    });
});

Могу поспорить, код jQuery может быть сокращен, но это понятно.

8 голосов
/ 15 июля 2011
$(<img />).attr('src','http://somedomain.com/image.jpg');

Должно быть лучше, чем ajax, потому что, если это галерея, и вы просматриваете список фотографий, если изображение уже находится в кеше, оно не отправит другой запрос на сервер.Он будет запрашивать в случае jQuery / ajax и возвращать HTTP 304 (не изменен), а затем использовать исходное изображение из кэша, если оно уже там.Вышеуказанный метод уменьшает пустой запрос к серверу после первого цикла изображений в галерее.

4 голосов
/ 21 октября 2014

Вы можете использовать отложенные объекты для загрузки ASYNC.

function load_img_async(source) {
    return $.Deferred (function (task) {
        var image = new Image();
        image.onload = function () {task.resolve(image);}
        image.onerror = function () {task.reject();}
        image.src=source;
    }).promise();
}

$.when(load_img_async(IMAGE_URL)).done(function (image) {
    $(#id).empty().append(image);
});

Обратите внимание: image.onload должен быть перед image.src во избежание проблем с кешем.

3 голосов
/ 02 ноября 2016

Это тоже работает ..

var image = new Image();
image.src = 'image url';
image.onload = function(e){
  // functionalities on load
}
$("#img-container").append(image);
3 голосов
/ 26 ноября 2010

Если вы просто хотите установить источник изображения, вы можете использовать это.

$("img").attr('src','http://somedomain.com/image.jpg');
2 голосов
/ 26 ноября 2010

используйте .load для загрузки вашего изображения. Чтобы проверить, если вы получаете ошибку (скажем, 404), вы можете сделать следующее:

$("#img_id").error(function(){
  //$(this).hide();
  //alert("img not loaded");
  //some action you whant here
});

осторожно - событие .error () не сработает, если атрибут src пуст для изображения.

2 голосов
/ 26 ноября 2010

AFAIK, вам бы пришлось сделать здесь функцию .load (), в отличие от .ajax (), но вы могли бы использовать jQuery setTimeout, чтобы сохранить его (ish)

<script>
 $(document).ready(function() {
 $.ajaxSetup({
    cache: false
});
 $("#placeholder").load("PATH TO IMAGE");
   var refreshId = setInterval(function() {
      $("#placeholder").load("PATH TO IMAGE");
   }, 500);
});
</script>
0 голосов
/ 20 февраля 2016

$ (function () {

    if ($('#hdnFromGLMS')[0].value == 'MB9262') {
        $('.clr').append('<img src="~/Images/CDAB_london.jpg">');
    }
    else
    {
        $('.clr').css("display", "none");
        $('#imgIreland').css("display", "block");
        $('.clrIrland').append('<img src="~/Images/Ireland-v1.jpg">');
    }
});
...