Miron Machnicki

Miron Machnicki Frontend Engineer

Temat: Konfilkt jQuery i Prototype

Witam,
Skrypty korzystające z jQuery często nie działają, jeśli korzystamy również z Prototype. Tutaj więcej info: http://blog.baobaz.com/pl/blog/prototype-i-jquery-w-ma...

Używam obu bibliotek w jednym projekcie - http://kultura.nysa.pl/. Aby wszystko dobrze działało, należy na końcu pliku jquery.js dodać kod:
var $j =  jQuery.noConflict();
, a następnie w każdym kodzie js korzystającym z jQuery zastąpić "$" znakiem "$j".

Udało mi się to ze sliderem top news, ale nie potrafię poprawić menu, które korzysta z jquery (droppy). Poniżej przedstawiam kod (oryginalny bez przekształceń):

<script language=javascript>
$.fn.droppy = function(options) {

options = $.extend({speed: 250}, options || {});

this.each(function() {

var root = this, zIndex = 1000;

function getSubnav(ele) {
if (ele.nodeName.toLowerCase() == 'li') {
var subnav = $('> ul', ele);
return subnav.length ? subnav[0] : null;
} else {
return ele;
}
}

function getActuator(ele) {
if (ele.nodeName.toLowerCase() == 'ul') {
return $(ele).parents('li')[0];
} else {
return ele;
}
}

function hide() {
var subnav = getSubnav(this);
if (!subnav) return;
$.data(subnav, 'cancelHide', false);
setTimeout(function() {
if (!$.data(subnav, 'cancelHide')) {
$(subnav).slideUp(options.speed);
}
}, 500);
}

function show() {
var subnav = getSubnav(this);
if (!subnav) return;
$.data(subnav, 'cancelHide', true);
$(subnav).css({zIndex: zIndex++}).slideDown(options.speed);
if (this.nodeName.toLowerCase() == 'ul') {
var li = getActuator(this);
$(li).addClass('hover');
$('> a', li).addClass('hover');
}
}

$('ul, li', this).hover(show, hide);
$('li', this).hover(
function() { $(this).addClass('hover'); $('> a', this).addClass('hover'); },
function() { $(this).removeClass('hover'); $('> a', this).removeClass('hover'); }
);

});

};
</script>


Znaki $ zastąpiłem $j, ale to nic nie zmienia. Czy ktoś orientuje się, o co może chodzić?

Już działa. Zapomniałem dodać na końcu:

<script type='text/javascript'>
$j(function() {
$j('#nav').droppy();
});
</script>
Miron Machnicki edytował(a) ten post dnia 21.07.10 o godzinie 20:33

konto usunięte

Temat: Konfilkt jQuery i Prototype

spróbuj

var J=jQuery.noConflict();


bez dolarkaMichał Ćwikliński edytował(a) ten post dnia 23.07.10 o godzinie 15:30

konto usunięte

Temat: Konfilkt jQuery i Prototype

Miron Machnicki:
Aby wszystko dobrze działało, należy na końcu pliku jquery.js dodać kod:
var $j =  jQuery.noConflict();
, a następnie w każdym kodzie js korzystającym z jQuery zastąpić "$" znakiem "$j".
Aby wszystko dobrze działało nie należy modyfikować wewnętrznego kodu biblioteki, tym bardziej pisać takich bezsensownych porad. Można dziedziczyć (pseudo-dziedziczyć, nie wiem jak to się zwie w js), przeciążać metody czy dać jQuery.noConflict() do pliku z naszym kodem javascript.

Następna dyskusja:

Drobny problemik - LightBox...




Wyślij zaproszenie do