如何通过单击jquery中的另一个菜单关闭一个菜单及其图标? [英] How to close one menu and its icon by clicking on another menu in jquery?

查看:69
本文介绍了如何通过单击jquery中的另一个菜单关闭一个菜单及其图标?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

当我点击一个菜单时,它会在菜单上显示并显示十字形,但当我点击搜索菜单时,它也会显示在同一菜单中并显示十字图标。

When I click on one menu it displays and show cross on the menu, but when I click on search menu it also displays in the same menu and display cross icon.

我想点击一个菜单关闭另一个菜单并将图标更改为默认值。

I want to click on one menu close another menu and change icon to its default.

$('.toggle-sm-nav, .js-toggle-sm-navigation').click(function(){

    // Change button
    $(this).children('span').toggleClass('glyphicon-align-justify icon-close-menu-cross2');
    $('.sm-searchboxc').find('i').removeClass('active');

    // Toggle menu on hamburger
    $('.navcontainer').toggle();
    $('.header-nav-container').toggleClass('brgropen');

    if( $('.header-nav-container').hasClass('brgropen') ){
        $('body').css('overflow', 'hidden');
    } else {
        $('body').css('overflow', 'visible');
    }

    // Focus search field when opened
    $('.js-toggle-xs-search').on('click', function(){
        $('.sm-searchboxc input#search').trigger('touchstart');

    });
    $('.sm-searchboxc input#search').on('touchstart', function(){
        setTimeout(function(){
            $('.sm-searchboxc input#search').focus();
        }, 0);    
   });

与菜单相关的HTML代码

HTML code related to menus

<div class="sm-navigation">
                <div class="row">

                    <div class="sm-nav col-xs-1 col-sm-1 visible-sm">
                        <button class="btn btn-default js-toggle-sm-navigation toggle-sm-nav btn-sm" type="button">
                            <span class="glyphicon glyphicon-align-justify"></span>
                        </button>
                    </div>

                    <div class="col-xs-12 col-sm-2 col-md-2 logocontainer">
                        <div class="site-logo">

                            <div class="content"><a href="/"><img src="/_ui/responsive/theme-blue/images/abc.svg"></a></div></div>
                    </div>

                    <div class="xs-nav col-xs-3 col-sm-3 visible-xs">
                        <button class="btn btn-default js-toggle-sm-navigation" type="button">
                            <span class="glyphicon glyphicon-align-justify"></span>
                        </button>
                    </div>

                    <div class="xs-store-finder col-xs-3 visible-xs ">
                        <a href="/store-finder">
                            <button class="btn btn-default btn-sm" type="button">
                                <span class="glyphicon icon-store-locator"></span>
                            </button>
                        </a>
                    </div>

                    <div class="xs-search col-xs-3 visible-xs">
                        <button class="btn btn-default js-toggle-xs-search toggle-xs-search btn-sm" type="button">
                                <span class="glyphicon icon-search"></span>
                            </button>
                        </div>

                    <div class="searchboxc md-searchboxc col-xs-12 col-sm-5 col-md-5 hidden-xs hidden-sm">
                        <div class="site-search ui-front">
    <form id="search-form" name="search-form" method="get" class="search-form ng-pristine ng-valid ng-scope ng-valid-maxlength" ng-submit="search.submit()" ng-controller="SearchController as search" action="/search/">


推荐答案

       if ($('.xs-search > button > span').hasClass('icon-close-menu-cross2')) {
         $('.xs-search > button > span').removeClass('icon-close-menu-cross2').addClass('icon-search');
         $('.sm-searchboxc input#search').hide();
         $('.searchboxc').find('.site-search').removeClass('active');
       }
       $('.navcontainer').toggle();
       $('.header-nav-container').toggleClass('brgropen');
       if ($('.header-nav-container').hasClass('brgropen'))

         $('.js-toggle-xs-search').on('click', function() {
         var width = $(window).width();
         if (width <= 968) {
           if ($('.sm-searchboxc input#search').hide()) {
             $('.sm-searchboxc input#search').show();
           } else if ($('.xs-search > button > span').hasClass('icon-close-menu-cross2')) {
             $('.sm-searchboxc input#search').trigger('touchstart');
           }
           if ($('.header-nav-container').hasClass('brgropen')) {
             $('.toggle-sm-nav, .js-toggle-sm-navigation').children('span').toggleClass('glyphicon-align-justify icon-close-menu-cross2');
             $('.navcontainer').hide();
             $('.header-nav-container').removeClass('brgropen');
           }
         } else {
           $('.sm-searchboxc input#search').trigger('touchstart');
         }
       });
       $('.sm-searchboxc input#search').on('touchstart', function() {
             setTimeout(function() {
                   $('.sm-searchboxc input#search').focus();

这篇关于如何通过单击jquery中的另一个菜单关闭一个菜单及其图标?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆