使用xml和jquery在同一节点中加载图像集

时间:2021-02-21 04:57:25

I am trying to load multiple images that corresponds to my node when I click my thumbnail.

当我点击我的缩略图时,我正在尝试加载与我的节点对应的多个图像。

I am able to get it to load 1 image when clicking but I need to load multiple images. I am

我可以让它在点击时加载1个图像,但我需要加载多个图像。我是

loading my thumbnail images with xml.

用xml加载我的缩略图。

var $container = $('.window_body');
var images = new Array();
var id = 0;
init();

function init() {
    $('<div class = "thumbnail_layout layout_type"></div>').appendTo('.window_body');
    $.get('sites.xml', function (d) {
        $(d).find('site').each(function (i, l) {
            var imageUrl = $(this).find('imgurl').text();
            var title = $(this).find('title').text();
            var url = $(this).find('url').text();
            var brief = $(this).find('brief').text();
            var long = $(this).find('long').text();
            var classa = $(this).find('_class').text();
            images[i] = $(this).find('img').text();
            $('<div id="' + "p" + i + '" class="' + classa + '"></div>').html('<a> <img src="' + imageUrl + '" class="thumbnail" />' + '<h1>' + title + '</h1> </a>').appendTo('.thumbnail_layout');
        });
        $(".item").click(function () {
            var index = $(this).prevAll().length;
            var datelength = $(".item").length
            for(var i = 0; i <= datelength; i++) {
                if(i == index) {
                    $("#holder").empty();
                    $("#holder").prepend('<img id="my_img" src="' + images[i] + '" />');
                } else {}
            }
        });
    })
}

XML:

XML:

<?xml version="1.0" encoding="iso-8859-1"?>
<sites>
    <site>
        <imgurl>images/thumbnail_big_a.jpg</imgurl>
        <title>test</title>
        <url>http://www.1.com</url>
        <desc>
            <brief>brief description.</brief>
            <long>long description</long>
        </desc>
        <bimgurl>
            <img>images/thumbnail_big_a.jpg</img>
            <img>images/thumbnail_big_b.jpg</img>
            <img>images/thumbnail_big_a.jpg</img>
        </bimgurl>
        <_class>item red</_class>
    </site>
</sites>

1 个解决方案

#1


1  

You could store the node set you get from $(this).find('img') instead of just the text:

您可以存储从$(this).find('img')获得的节点集,而不仅仅是文本:

        images[i] = $(this).find('img').text(); 

Then in the click handler do something like:

然后在click处理程序中执行以下操作:

images[i].each(function() {
    $("#holder").prepend('<img id="my_img" src="' + $(this).text + '" />');  
};

#1


1  

You could store the node set you get from $(this).find('img') instead of just the text:

您可以存储从$(this).find('img')获得的节点集,而不仅仅是文本:

        images[i] = $(this).find('img').text(); 

Then in the click handler do something like:

然后在click处理程序中执行以下操作:

images[i].each(function() {
    $("#holder").prepend('<img id="my_img" src="' + $(this).text + '" />');  
};