Заставить плагины jquery работать после вызова Ajax
Это будет длинный пост, но у меня действительно было достаточно попыток исправить это. Мне действительно нужна помощь в решении моего дела.
Первый:
fade.js
:
$(document).ready(function(){
$(".gallery ul li img.a").fadeTo("slow", 0.5); // This sets the opacity of the thumbs to fade down to 30% when the page loads
$(".gallery ul li img.a").hover(function(){
$(this).fadeTo("slow", 1.0); // This should set the opacity to 100% on hover
},function(){
$(this).fadeTo("slow", 0.5); // This should set the opacity back to 30% on mouseout
});
});
Проблема здесь в том, что после вызова ajax на следующей странице, исчезновение перестает работать. Так что я сделал, это
$(document).ready(function(){
$(".gallery ul li img.a").fadeTo("slow", 0.5); // This sets the opacity of the thumbs to fade down to 30% when the page loads
$(".gallery ul li img.a").live("hover", function(){
$(this).fadeTo("slow", 1.0); // This should set the opacity to 100% on hover
},function(){
$(this).fadeTo("slow", 0.5); // This should set the opacity back to 30% on mouseout
});
});
Но это будет работать только тогда, когда я наведу курсор мыши на изображение, тогда изображение исчезнет. Если я сделаю то же самое для $(".gallery ul li img.a").fadeTo
в .live(...)
ничего не происходит, просто не работает
- как можно заставить это работать даже после вызова ajax, который должен исчезнуть при загрузке, а затем исчезнуть при наведении на него курсора.
Во-вторых:
У меня есть маленький слайдер, который скользит вверх по изображению, slider.js
:
$(document).ready(function(){
//To switch directions up/down and left/right just place a "-" in front of the top/left attribute
//Full Caption Sliding (Hidden to Visible)
$('.gallery li').hover(function(){
$(".cover", this).stop().animate({top:'106px'},{queue:false,duration:160});
}, function() {
$(".cover", this).stop().animate({top:'153px'},{queue:false,duration:160});
});
});
Я изменился $('.gallery li').hover(...)
в $('.gallery li').live("hover", function(){...})
но все равно это не сработало. Также я использовал .on
вместо .live
потому что это устарело.
Что я делаю неправильно? Я не клиент, чувак, большая часть моей работы на стороне сервера. Мне просто нужно, чтобы эти 2 плагина работали после вызова AJAX.
Ajax:
@dajaxice_register
def gallerypages(request, p):
try:
page = int(p)
except:
page = 1
items = gallerylist(page)
html = render_to_string('gallery_content.html',
{'items': items,},
context_instance = RequestContext(request))
dajax = Dajax()
dajax.assign('#gallery-content', 'innerHTML', html)
return dajax.json()
Edit2:
<a href="#" onclick="Dajaxice.gallery.gallerypages(Dajax.process, {'p': {{ items.previous_page_number }},})" class="btn_prev"><b><</b></a>
а также
$(document).on("keydown", "#pagenumber", function(e)
if ( e.which === 13 ) {
Dajaxice.gallery.gallerypages(Dajax.process, {'p': this.value});
}});
3 ответа
Я не уверен, но проверь это:
JavaScript через JQuery
var initFade = function() {
$(".gallery ul li img.a").fadeTo("slow", 0.5);
}
// your custom callback method
var reBindStuffs = function(data) {
Dajax.process(data);
// rebind your jquery event handlers here... e.g.
initFade();
};
$(document).ready(function(){
// initial first time loaded fade
initFade();
// hover live binder
$(".gallery ul li img.a").live("hover", function(){
$(this).fadeTo("slow", 1.0);
},function(){
$(this).fadeTo("slow", 0.5);
});
// document keydown listener
$(document).on("keydown", "#pagenumber", function(e)
if ( e.which === 13 ) {
Dajaxice.gallery.gallerypages('reBindStuffs', {'p': this.value});
}});
});
HTML
<!-- a click listener -->
<a href="#" onclick="Dajaxice.gallery.gallerypages(reBindStuffs, {'p': {{ items.previous_page_number }},})" class="btn_prev"><b><</b></a>
То, что вы упоминаете, является большой проблемой, я освежаю от руки. Но я также использую функциональность.ajaxcomplete. Он запускается каждый после каждого запроса Ajax
$(document).ajaxComplete(function(){
// Carga tabs por defecto por clases.
if (typeof jQuery.fn.wf_responsivetab == 'function')
{
if ($('#rbtt_1').length)
{
$('#rbtt_1').wf_responsivetab({text: '...',});
$(window).on('resize', function() {$('#rbtt_1').wf_responsivetab({text: '...',});});
}
}
});
Вы двигались в правильном направлении с live
, но live
амортизируется за on
событие. С on
Вы можете включить селектор в качестве одного из аргументов. Первоначальный селектор jQuery является только контейнером объектов, к которым вы хотите добавить обработчики.
<div id="content">
<div class="sombutton"></div>
</div>
$( document ).ready( function() {
$( '#content' ).on( 'click', '.somebutton', function() {
alert( 'do something' );
} );
} );
Теперь, даже если мы заменим контент в #conent
div, недавно добавленный контент с классом .somebutton
также будет прикреплен обработчик кликов.