trying to narrow down <a>
hrefs
to one with jQuery
filter and then add the tag active
class.
I am doing this because I get redirected from sidebar submenu and want to still keep sidebar menu open.
$(document).ready(function () {
var url = window.location;
$('ul.treeview-menu a').filter(function () {
return url.indexOf(this.href) > -1;
}).parentsUntil(".sidebar-menu > .treeview-menu").addClass('active');
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<ul class="sidebar-menu" data-widget="tree">
<li class="header">General</li>
<li class="home"><a href="/p/index.php"><i class="fas fa-tachometer-alt"></i> <span> Dashboard</span></a></li>
<li class="header">Data Managment</li>
<li class="treeview">
<a href="#">p <span>Tree</span>
<span class="pull-right-container">
<i class="fa fa-angle-left pull-right"></i>
</span>
</a>
<ul class="treeview-menu">
<li><a href="/p/pages/foo.php">foo</a></li>
<li><a href="/p/pages/bar.php">bar</a></li>
<li><a href="/p/pages/blah.php">blah</a></li>
<li><a href="/p/pages/blahh.php">blahh</a></li>
</ul>
</li>
<li class="treeview">
<a href="#"></i> <span>Tree 2</span>
<span class="pull-right-container">
<i class="fa fa-angle-left pull-right"></i>
</span>
</a>
<ul class="treeview-menu">
<li><a href="/p/pages/aaa.php">aaa</a></li>
...
</ul>
</li>
</ul>
then if I get redirected inside foo
and href
be like /p/pages/foo.php/new.php
I still want to foo be active.
why don't this work?