Disabling normal link behaviour on click with an if statement in Jquery?

Posted by Qwibble on Stack Overflow See other posts from Stack Overflow or by Qwibble
Published on 2010-05-22T17:45:48Z Indexed on 2010/05/22 17:50 UTC
Read the original article Hit count: 346

Filed under:
|
|
|
|

I've been banging my head with this all day, trying anything and everything I can think of to no gain. I'm no Jquery guru, so am hoping someone here can help me out. What I'm trying to do in pseudo code (concept) seems practical and easy to implement, but obviously not so =D

What I have is a navigation sidebar, with sub menu's within some li's, and a link at the head of each li.

When a top level link is clicked, I want the jquery to check if the link has a sibling ul. If it does, the link doesn't act like a link, but slides down the sibling sub nav. If there isn't one, the link should act normally.

Here's where I'm at currently, what am I doing wrong?

$('ul.navigation li a').not('ul.navigation li ul li a').click(function (){
    if($(this).parent().contains('ul')){
        $('ul.navigation li ul').slideUp();
        $(this).siblings('ul').slideDown();
        return false;
    }
    else{
        alert('Link Clicked')
        // Maybe do some more stuff in here...
    }
});

Any ideas?

© Stack Overflow or respective owner

Related posts about jQuery

Related posts about html