开发者

Jquery $(this) Child Selector Not working for some unknown reason

开发者 https://www.devze.com 2023-04-05 03:40 出处:网络
I am trying to show/hide the child class when parent is hovered. I have multiple class set like in Jquery $(this) Child Selector.

I am trying to show/hide the child class when parent is hovered. I have multiple class set like in Jquery $(this) Child Selector.

for some unknown reason it is not working.

What I have is

<div class="parentitem">
    <div class="childitem">
    </div>
</div>

Also

$("div.childitem").css({visibility: "hidden"});

$("div.parentitem").mouseenter(function(){
    $("div.childitem").css({visibility: "visible"});
});

$("div.parentitem").mouseleave(function(){
    $("div.childitem").css({visibility: "hidden"});
});

This works but all the children are aff开发者_开发知识库ected. What I wanted is to affect only particular div and its child

I tried to use

$(this).children("div.childitem").css({visibility: "visible"});

$(this).parent().children("div.childitem").css({visibility: "visible"});

$(this).next("div.childitem").css({visibility: "visible"});

None of this is working for some reason.

Can somebody point me where I went wrong.

Thanks

Deepak


Try:

$("div.childitem").css({visibility: "hidden"});

$("div.parentitem").mouseenter(function(){
    $(this).find('.childitem').css({visibility: 'visible'});
});

$("div.parentitem").mouseleave(function(){
    $(this).find('.childitem').css({visibility: 'hidden'});
});

JS Fiddle demo.


Try $(this).find("div.childitem") instead of $(this).children("div.childitem").

children() finds the immediate children only, while find() searches among all children, i.e. the children's children and their children and so on.

If that still doesn't work, I suggest to anaylze the order in which all related event handlers are called. Might be that the result of the mouseenter event handlers is instantly undone by some other event handler.

In Chrome or with Firebug in Firefox you can log to the console. E.g. for Chrome it's console.log(text_or_object).


I think this is what you'll need:

$("div.parentitem").mouseenter(function(){
    $(this).find("div.childitem").css({visibility: "visible"});
});


You need to use $(this) as the selector context ie

$("div.childitem",$(this))

Though there is probably a more elegant solution...


This might be interesting: http://jsfiddle.net/DrkwB/2/

I just modified an existing example to accommodate multiple content areas and then the particular parent that is hovered on, its child element is hidden or shown accordingly.

0

精彩评论

暂无评论...
验证码 换一张
取 消