2011-04-21 53 views
0

爲什麼jQuery不是點擊「合法」鏈接?它適用於 「添加...」 鏈接..jQuery莫代爾窗口沒有在第二個鏈接上觸發?

HTML>

<div id="top_function"> 
    <div class="functions" style="margin-top:7px;"><img src="img/addProfIcon.png" width="32" height="32" /> 
     <h4><a href="#?w=500" rel="popup_name" class="poplight">Add...</a></h4><!-- ADD PROF/COURSE --> 
    </div><!--function1--> 
    <!--<div class="functions"><img src="img/disclaimerIcon.png" width="32" height="32" /><h4><a href="#">Compare</a></h4></div>--> 
    <div class="functions"><img src="img/disclaimerIcon.png" width="32" height="32" /> 
     <h4><a href="#?w=500" rel="popup_name2" class="poplight2">Legal</a></h4> 
    </div><!--function3--> <!-- LEGAL --> 
    <div class="functions"><img src="img/contactIcon.png" width="32" height="32" /><h4><a href="#">Contact</a></h4></div><!--function4--> <!-- CONTACT --> 
</div> 

Modal.js>

$(document).ready(function() { 
$('a.poplight[href^=#]').click(function() { 
    var popID = $(this).attr('rel'); //Get Popup Name 
    var popURL = $(this).attr('href'); //Get Popup href to define size 

    //Pull Query & Variables from href URL 
    var query= popURL.split('?'); 
    var dim= query[1].split('&'); 
    var popWidth = dim[0].split('=')[1]; //Gets the first query string value 

    //Fade in the Popup and add close button 
    $('#' + popID).fadeIn().css({ 'width': Number(popWidth) }).prepend('<a href="#" class="close"><img src="img/close.png" class="btn_close" title="Close Window" alt="Close" /></a>'); 

    //Define margin for center alignment (vertical horizontal) - we add 80px to the height/width to accomodate for the padding and border width defined in the css 
    var popMargTop = ($('#' + popID).height() + 80)/2; 
    var popMargLeft = ($('#' + popID).width() + 80)/2; 

    //Apply Margin to Popup 
    $('#' + popID).css({ 
     'margin-top' : -popMargTop, 
     'margin-left' : -popMargLeft 
    }); 

    //Fade in Background 
    $('body').append('<div id="fade"></div>'); //Add the fade layer to bottom of the body tag. 
    $('#fade').css({'filter' : 'alpha(opacity=80)'}).fadeIn(); //Fade in the fade layer - .css({'filter' : 'alpha(opacity=80)'}) is used to fix the IE Bug on fading transparencies 

    return false; 
}); 

//Close Popups and Fade Layer 
$('a.close, #fade').live('click', function() { //When clicking on the close or fade layer... 
    $('#fade , .popup_block').fadeOut(function() { 
     $('#fade, a.close').remove(); //fade them both out 
    }); 
    return false; 
}); 
}); 

實際模態窗口的內容(現在):

測試

回答

0

你只設置錨標籤單擊處理與poplight類。您的「法律」鏈接改爲poplight2

+0

不那麼容易,每個類和div都有自己的一組數據。通過做poplight(2x)..它顯示相同的數據集 – Jshee 2011-04-21 01:43:03

+0

@ user700070:嗯?我只是解釋你的代碼爲什麼不「工作」。你有上述不一致。 – 2011-04-21 01:43:54

+0

嗯,我說的是'poplight2'是有原因的,因爲每個鏈接彈出一個新的模式窗口不同的內容,所以'poplight'中的內容不同於'poplight2'。 – Jshee 2011-04-21 01:46:29