我在一個div中隱藏了一個無序列表。該div有一個'.feed-label'類,我現在正在顯示div在div被懸停時的情況。
我的問題是,當鼠標懸停的所有其他元素也顯示出,我只希望這是盤旋在展現一個。
我不知道如何使用$(本)。在事件處理程序的上下文
$('.feed-label').hover(function() {
$('.article-interactive-buttons').toggleClass('hide');
});
我在一個div中隱藏了一個無序列表。該div有一個'.feed-label'類,我現在正在顯示div在div被懸停時的情況。
我的問題是,當鼠標懸停的所有其他元素也顯示出,我只希望這是盤旋在展現一個。
我不知道如何使用$(本)。在事件處理程序的上下文
$('.feed-label').hover(function() {
$('.article-interactive-buttons').toggleClass('hide');
});
this
關鍵字指懸停的元件,即.feed-label
元件。你應該元素傳遞給jQuery構造函數創建一個jQuery對象,然後使用find
/children
方法爲選擇目標後裔。
$('.feed-label').hover(function() {
$(this).find('.article-interactive-buttons').toggleClass('hide');
});
您也可以使用$(selector, context)
語法,會像上面的代碼片段:
$('.feed-label').hover(function() {
$('.article-interactive-buttons', this).toggleClass('hide');
});
哇,我想知道這些年來我是如何錯過'selector,context'語法的。棒極了。 – max
你可以試試:
$('.feed-label').hover(function() {
$(this).closest('.article-interactive buttons').toggleClass('hide');
}
是的,它是找到而不是找到。我誤解了這個問題。 – didando8a
如果UL是div內,和你想去的CSS唯一的解決辦法,你可以這樣做:
.feed-label:hover .article-interactive-buttons {
display: none;
}
.feed-label:hover .article-interactive-buttons {
display: block;
}
如果你想懸停元素中切換的元素,你可以做'$(本).find(選擇).toggleClass(「隱藏」);' – hamstu
的UL已經在使用類隱躲,toggleClass是添加和懸停 – edward
@hamstu感謝隊友刪除它,你是一個傳奇 – edward