JQuery - добавляет onclick к динамически генерируемому тегу img - PullRequest
9 голосов
/ 15 мая 2009

Я создаю несколько изображений динамически, используя следующий код:

function refresh_gallery(galleryidentifier, albumid) {
    $.ajax({ type: "POST", url: "/Photos/Thumbnails/" + albumid + "/", data: {}, success: function(msg) {
        try {
            var fotos = eval(msg); $(galleryidentifier).empty(); if (fotos.length == 0) { $(galleryidentifier).html("Press "Add files..." and select files to upload!"); return true; }
            for (var f in fotos) {
                //this image needs the onclick eventhandler
                $(document.createElement("img")).attr({ src: '/images/delete.gif', title: 'Delete ' + fotos[f].Title }).addClass("icon_delete").appendTo(galleryidentifier); ;
                $(document.createElement("img")).attr({ src: fotos[f].ThumbnailPath, title: fotos[f].Title }).addClass("thumbnail").appendTo(galleryidentifier);
            }
            var del_div = $(document.createElement("div")).css({ "padding": "4px" }).appendTo(galleryidentifier);
            var delete_span = $(document.createElement("span")).click(delete_files(albumid)).css({ "cursor": "pointer", "font-size": "12px" }).appendTo(del_div);
            $(document.createElement("img")).attr({ "src": "/Content/images/delete.png" }).appendTo(delete_span);
            $(document.createTextNode("delete all")).appendTo(delete_span);
            return true;
        }
        catch (e) {
            alert(e);
        }
        alert("Refresh error!");
    }, error: function() { alert("Refresh error!"); }
    });
}

Генерация изображений работает нормально, но я хочу добавить обработчик событий onclick к первому генерируемому изображению (см. Комментарий в коде). Как мне это сделать? Я довольно новичок в JQuery.

Спасибо!

Ответы [ 5 ]

16 голосов
/ 15 мая 2009
$(document.createElement("img"))
    .attr({ src: '/images/delete.gif', title: 'Delete ' + fotos[f].Title })
    .addClass("icon_delete")
    .appendTo(galleryidentifier)
    .click(function(){
        // Do something
    })
9 голосов
/ 15 мая 2009

В jQuery есть метод click, аргументом которого является функция обратного вызова. В этом примере я также собираюсь использовать (намного) более простое сокращение для создания элемента изображения:

$('<img/>').click(function () {
    // do something
}).attr({
    src: '/images/delete.gif',
    title: 'Delete ' + fotos[f].Title
}).addClass("icon_delete").appendTo(galleryidentifier);
5 голосов
/ 25 апреля 2012

Начиная с jQuery 1.4, вы можете создавать элемент и добавлять все атрибуты / события к нему при создании.

В случае тега изображения вы должны написать:

$('<img/>', {
    src:     '/images/delete.gif',
    title:   'Delete ' + fotos[f].Title,
    'class': 'icon_delete', // in quotes because class is a reserved js word
    click:   function( e ){
        // Everything here happens when you click the image.
    }
}).appendTo(galleryidentifier);

Свыше пример в JSBin.

Вот ссылка на документы.

Почему это лучше, чем другие способы создания изображения с помощью jQuery:

  • Гораздо чище, чем цепочка из дюжины методов.
  • Позволяет отправлять объекты с различными свойствами для создания.
  • Прекрасно сочетается с обычным html-элементом с жестким кодом.
1 голос
/ 15 мая 2009

Вы можете просто создать класс при создании изображения с помощью метода addClass (). А в другом месте есть что-то вроде

$(document).ready(
  $("img.toBeClicked").click(function() {
    //some code
  };
};
1 голос
/ 15 мая 2009

Вы можете добавить обработчик событий этого типа, используя функцию click так же, как вы добавили класс css.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...