0

我找到并编辑了这段代码,以使用 jquery 在网页上显示来自在线日历的 xml 提要的元素。有没有办法让我包含条件,以便我可以在填充节点时显示来自节点的信息,并在节点为空时忽略它?例如,要包含 imagepath、imagetext 和必要的 html 来格式化它,但在没有 imagepath 和 imagetext 信息时忽略所有这些?

<script>
$(document).ready(function () {
    $.ajax({
        type: "GET",
        url: "http://orion.lib.mi.us/evanced/lib/eventsxml.asp?dm=exml&lib=0&nd=90",
        dataType: "xml",
        success: xmlParser,
        error: function(){alert("We're sorry. Something didn't load correctly.");}
    });
});

function xmlParser(xml) {
    $(xml).find("item").each(function () {
        var xml_image       = $(this).find('imagepath').text();
        var xml_imagetext   = $(this).find('imagetext').text();
        var xml_title       = $(this).find('title').text();
        var xml_date        = $(this).find('date').text();
        var xml_time        = $(this).find('time').text();
        var xml_location    = $(this).find('location').text();
        var xml_link        = $(this).find('link').text();
        var xml_description = $(this).find('description').text();
        $(".main").append('<div class="event"><div class="logo"><img alt="' + xml_imagetext + '" src="' + xml_image + '" /></div><p class="title"><a href="' + xml_link + '">' + xml_title + '</a></p><p class="when">' + xml_date + ' at ' + xml_time + '</p><p class="location">Location: ' + xml_location + '</p><p class="description">' + xml_description + '</p><p class="link"><a href="' + xml_link + '">More Information</a></p></div>');
    });}
</script>
4

1 回答 1

1

您可能希望在将内容附加到main之前简单地添加一个条件。

if (xml_image != "" && xml_imagetext != "") {
    $(".main").append...
}

或者,如果您想显示不同的内容,请执行以下操作:

var hasImage = xml_image != "" && xml_imagetext != "";
var html = "<div class='event'>" +
    ((hasImage) ? "<img src='" + xml_image + "' alt='" + xml_imagetext + "' />" : "")
    + "</div>";
于 2012-05-22T18:02:49.867 回答