2009-06-24 5 views
0

Ich habe den folgenden Code ein Popup-div anzuzeigen:jQuery: Cascading Popups

<a href="#" id="pop1" rel="div#tt1">Click to show popup</a> 
<div class="popupBlock" id="tt1">My popup content ...</div> 

Die div versteckt ist zunächst und mit ein bisschen jQuery-Code Ich drehe es sichtbar, wenn pop1 Anker geklickt wird . Dies ist die plgin ich dafür gemacht habe:

<div class="popupBlock" id="tt1">My popup content ... 
     <span> some text here</span> 
</div> 

The:

(function($) { 
$.fn.pop = function(options) { 


    var defaults = { 
     show: "click", 
     tooltip: null 
    }; 
    var options = $.extend(defaults, options); 
    var target = $(this); 
    var popup = $(target.attr("rel")); 

    popup.css("visibility", "hidden").css("display", "none"); 
    target.click(function() { 
     popup.css("visibility", "visible").css("display", "block"); 
     return false; 
    }); 

    $('body').click(function() { 
     popup.css("visibility", "hidden").css("display", "none"); 
     return false; 
    }); 

    popup.click(function(event) { 
     event.stopPropagation(); 
    }); 
}; 

Alles scheint in Ordnung zu sein, aber die ganze Sache bricht, wenn ich eine Kontrolle in der div, wie hinzufügen span löst das click -Ereignis des div nicht aus und blendet das div aus, was ich nicht möchte. Hat jemand eine Idee, was ich tun muss, um dies zu verhindern? Danke, V

Antwort

0
var popup = $(target.attr("rel")).add($(target.attr("rel") > *)); 

oder

var popup = $(target.attr("rel"), $(target.attr("rel") > *));