在同一页面中同时使用Prototype和jQuery的问题

时间:2011-06-07 22:36:37

标签: javascript jquery prototypejs conflict

当我使用jquery脚本进行内联窗口和原型来设置菜单时,我遇到了冲突。当我使用其中一个工作正常。但是当我同时使用它们时,只有原型才有效。我读到了一个关于jquery.noconflict但我可以正确使用它。 这些是脚本。

这是我的jquery脚本(内联窗口)     

<script type="text/javascript">

$(document).ready(function(){

    //When you click on a link with class of poplight and the href starts with a # 
    $('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('');

        //Define margin for center alignment (vertical + horizontal) - we add 80 to the height/width to accomodate for the padding + 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 

        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;
    });


});

</script>

这是我的原型脚本

<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/prototype/1.7.0.0/prototype.js"></script>  

<script type="text/javascript">  
// <![CDATA[  
// Making sure this code only executes when the document is loaded: this makes the DOM available to us  
Event.observe(document, 'dom:loaded', function() {  

    // for every element with an toggler class...  
    $$('.toggleExample').each(function(element) {  

        // we put on an event listener of the click type  
        Event.observe(element, 'click', function(event){   

            // We stop the default link behaviour  
            Event.stop(event);  

            // when clicked, traverse the DOM: 1 step up (from it's A-element to it's container DIV-element),   
            // and select its following sibling (next(0)), and toggle that shit.  
            Event.element(event).up(0).next(0).toggle();  

        }, false);  

    });  

});  
// ]]>  
</script>  

3 个答案:

答案 0 :(得分:5)

在嵌入式jquery.js之后放右:

<script  type="text/javascript">
$.noConflict();
</script>

并更改此行:

$(document).ready(function(){

jQuery(document).ready(function($){

答案 1 :(得分:2)

首先加载jQuery,然后调用

jQuery.noConflict(); 
//if loaded first, you could also use $.noConflict(), 
//but consistency is a good thing

然后继续加载剩下的东西(包括Prototype,自定义脚本等)。

最后(这与你上面的第一个例子有关)使用你通常使用$的函数jQuery。


你的基本问题是Prototype和jQuery都使用$作为对另一个函数的引用。不幸的是,Prototype或多或少需要它的$定义,这意味着一旦加载,其他任何东西都不应该命名为$。 jQuery的noConflict方法摆脱了$方法来防止这个问题。

答案 2 :(得分:2)

1.-加载jQuery库。 2.-你的jQuery的东西 3.-加载原型库 4.-你的Prototype东西

你应该在jQuery上使用noConflict函数,你的jQuery东西应该这样开始:

<script type="text/javascript">
jQuery.noConflict();
jQuery(function($){

    //All my jQuery stuff

});
</script>

如果您需要更多信息,请查看jQuery API http://api.jquery.com/jQuery.noConflict/