jquery导航问题,不得不双击

时间:2013-07-22 20:30:44

标签: jquery navigation click nav

我有一个导航,您可以在此处看到:http://hutchcreative.co.uk/rod/

如果单击菜单图标(右上角),则会显示暗导航菜单。如果您点击联系我们,然后打开白色联系我们部分。然后单击菜单图标以关闭所有内容。如果您再次单击菜单图标,它将像以前一样打开暗导航,但如果您单击联系人,它将无法打开。您必须再次单击它以打开白色联系人部分。有没有人知道如何解决这个问题?

这是我的jquery:

jQuery(function($) {    
$('#menuIcon').toggle(function(){
       $('#navigationWrapper ul').hide();
       $('#navigationWrapper ul').show();
       $("#navigationWrapper").css("background-color", "rgba(0,0,0,0.3)");
},function(){
       $('#navigationWrapper ul').show();
       $('#navigationWrapper ul').hide();
       $("#navigationWrapper").css("background-color", "rgba(0,0,0,0.0)");
});

$('#menu-item-56').toggle(function(){
       $('#contactWrapper').hide();
       $('#contactWrapper').show();
       $("#navigationWrapper").addClass('whiteSection');
       $("#navigationWrapper").css("background-color", "rgba(255,255,255,1)");
},function(){
       $('#contactWrapper').show();
       $('#contactWrapper').hide();
       $("#navigationWrapper").removeClass('whiteSection');
       $("#navigationWrapper").css("background-color", "rgba(0,0,0,0.3)");
});

$("#menuIcon").click(function ( event ) {
    event.preventDefault();
    $('#contactWrapper').hide();
    $("#navigationWrapper").removeClass('whiteSection');
    if($('#contactWrapper').is(":visible")) {  $('#contactWrapper').hide(); }
});

});

这是我的HTML

<nav id="navigationWrapper">
    <div class="container">
        <div class="row">
            <div class="span6">
                <div id="logo"></div>
            </div>
            <div class="span6">
                <div id="menuIcon"></div>
                <ul>

                    <?php wp_nav_menu( array( 'theme_location' => 'primary', 'container' => false, 'menu_class' => 'menu', 'menu_id' => 'menu', 'depth' => 1, 'fallback_cb' => '', 'items_wrap' => '%3$s' ) ); ?>

                    <?php get_template_part( 'part', 'social' ); ?>

                </ul>
            </div>
        </div>
    </div>
</nav>

<div id="contactWrapper" >
    <div class="container">
        <div class="row">
            <?php
                    // query for the about page
                    $your_query = new WP_Query( 'pagename=contact' );
                    // "loop" through query (even though it's just one page) 
                    while ( $your_query->have_posts() ) : $your_query->the_post(); ?>
                        <div class="span6">
                            <?php the_title(); ?>
                            <?php the_content(); ?>
                        </div>
                        <div class="span6">
                            <?php the_field('email_address'); ?>
                        </div>
                <?php endwhile;
                // reset post data (important!)
                wp_reset_postdata();
                ?>
        </div>
    </div>
</div>

1 个答案:

答案 0 :(得分:1)

那是因为您正在使用.toggle() event(顺便说一下,已弃用)。单击菜单不是切换功能,通常会隐藏联系人菜单。

请改为尝试:

$('#menu-item-56').click(function(){
    if($("#navigationWrapper").hasClass('whiteSection')){
        $('#contactWrapper').show();
        $('#contactWrapper').hide();
        $("#navigationWrapper").removeClass('whiteSection');
        $("#navigationWrapper").css("background-color", "rgba(0,0,0,0.3)");
    }else{
        $('#contactWrapper').hide();
        $('#contactWrapper').show();
        $("#navigationWrapper").addClass('whiteSection');
        $("#navigationWrapper").css("background-color", "rgba(255,255,255,1)");
    }
});

关闭或打开菜单取决于它是否有课程,但我无法测试它。

当然可以优化代码,但这不是实际问题!