Tuesday, 5 November 2019

Add active class using js.

Menu Format
<ul class="rd-navbar-nav">
<li class="rd-nav-item"><a class="rd-nav-link" href="#">Home</a>
</li>
</ul>

 jQuery(function ($) {
    $("ul a").click(function(e) {
            var link = $(this);

            var item = link.parent("li");
            
            if (item.hasClass("active")) {
                item.removeClass("active").children("a").removeClass("active");
            } else {
                item.addClass("active").children("a").addClass("active");
            }

            if (item.children("ul").length > 0) {
                var href = link.attr("href");
                link.attr("href", "#");
                setTimeout(function () { 
                    link.attr("href", href);
                }, 300);
                e.preventDefault();
            }
        })
        .each(function() {
            var link = $(this);
            if (link.get(0).href === location.href) {
                link.addClass("active").parents("li").addClass("active");
                return false;
            }
        });
});

Add active class Laravel with JS .

Matching URL Segment :
<li class="{{ (request()->segment(2) == 'cities') ? 'active' : '' }}">  

So, this one will match any URL like /admin/cities/user/cities/edit etc.

Starting with the URL

<li class="{{ (request()->is('admin/cities*')) ? 'active' : '' }}">  

/admin/cities/create or /admin/cities/1/edit.

Exact URL
<li class="{{ (request()->is('admin/cities')) ? 'active' : '' }}">  
Probably, the most simple one – you just check the exact URL and see if it matches: