jQuery两个语句显然有冲突,但我找不到原因

时间:2012-10-19 13:13:50

标签: jquery

我为特定的类提供了一组简单的jQuery语句:

$(".printersToggle").mouseover(function() { 
    $(this).addClass("printersToggleOver");
}); 
$(".printersToggle").mouseout(function() { 
    $(this).removeClass("printersToggleOver");
});

$(".printersToggle").click(function() {
    var id = $(this).attr('id');
    $.getJSON("/ajax", 
            function(data) {
                $.each(data, function(key, val) { 
                    $("#" + id).replaceWith('<div class="row printersToggle" id="' + id '"><div class="twelve columns">Show printers (Best price: £4.65)</div></div><!-- end of printers toggle --><!-- printers --><div class="row" id="printers"><table><thead><tr><th>Title</th><th>Rating (%)</th><th>Experience (jobs)</th><th>Average job speed (days)</th><th>Reliability (%)</th><th>Cost</th><th>Print</th></tr></thead><tbody><tr><td id="printersName_{{ design.id }}"></td><td id="printersRating"></td><td>4</td><td>2</td><td>96</td><td>£4.56</td><td class="success printButton radius">Add to Cart</td></tr></tbody></table></div>');  
                });
            });
     });
}); 

没有第二个(点击功能),第一个按预期工作。使用第二个语句,鼠标悬停效果停止工作。知道这里发生了什么吗?

5 个答案:

答案 0 :(得分:4)

当您调用replaceWith()时,您将删除以前的DOM元素以及与之关联的任何事件处理程序。您应该使用带有选择器的on()来动态绑定事件处理程序:

$('#parentContainer').on('mouseover', '.printersToggle', function() { ... });

答案 1 :(得分:1)

请改用此代码:

$("body").on("mouseover",".printersToggle" ,function(){$(this).addClass("printersToggleOver");
});


$("body").on("mouseout",".printersToggle" ,function(){$(this).removeClass("printersToggleOver");
});

答案 2 :(得分:1)

您可以使用 .hover()功能,看看是否有帮助

$(".printersToggle").hover(function() { 
    $(this).addClass("printersToggleOver");
}, 
function() { 
    $(this).removeClass("printersToggleOver");
});

答案 3 :(得分:1)

您是否尝试过使用hover代替mouseover / mouseout

$(".printersToggle").hover(function() { 
    $(this).addClass("printersToggleOver");
}, function() { 
    $(this).removeClass("printersToggleOver");
});

答案 4 :(得分:1)

尝试:

$(document).ready(function () {
$(".printersToggle").hover(function() { 
        $(this).toggleClass("printersToggleOver");
    });
});