简体   繁体   English

如何使用jQuery更改bootstrap中的.active类

[英]how to change .active class in bootstrap using jquery

i am using django, and try to create a base template. 我正在使用django,并尝试创建基本模板。 I want to change the .active class in navbar links which points to a seperate link, Eg. 我想在导航栏链接中更改.active类,该类指向单独的链接,例如。 Home link in navbar points to home.html, About Us link in navbar points to about.html. navbar中的主页链接指向home.html,navbar中的About Us链接指向about.html。

I have also used a code in jquery to do that but it is not working. 我也在jquery中使用了一个代码来做到这一点,但是它不起作用。 Please suggest any method to do that. 请建议采取任何方法。

Please don't bother i am a newbie!!! 请不要打扰我是新手!!!

<!DOCTYPE html>
<html>
<head>
    {% load staticfiles %}
    <meta charset="UTF-8">

    <title>{% block title %}{% endblock %} | Vasu Genset Pvt. Ltd.</title>

    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">

    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>

    <link rel="stylesheet" href="https://bootswatch.com/paper/bootstrap.min.css">

    <link rel="stylesheet" type="text/css" href="{% static 'index/css/index.css' %}">

    <link rel="stylesheet" href="{% static 'index/css/products-style.css' %}">

    {% block style %}{% endblock %}


</head>
<body>

    <nav class="navbar navbar-default">
        <div class="container">
            <div class="navbar-header">
                <a class="navbar-brand" href="/home/" >Vasu Genset Pvt. Ltd.</a>
                <button class="navbar-toggle collapsed" data-toggle="collapse" data-target="#mydropdown">
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                </button>
            </div>
            <div class="collapse navbar-collapse" id="mydropdown">
                <ul class="nav navbar-nav navbar-right" id="navbar-change">
                    <li class="active"><a href="/home/">Home</a></li>
                    <li><a href="/aboutus/">About Us</a></li>
                    <li class="dropdown">
                    <a href="/productsandservices/" class="dropdown-toggle" data-toggle="dropdown">Products & Services <span class="caret"></span></a>
                        <ul class="dropdown-menu">
                            <li><a href="/generatorrepair/">Generator Repair</a></li>
                            <li><a href="/generatormaintenance/">Generator Maintenance</a></li>
                            <li><a href="/alternator/">Alternator Repair & Maintenance</a></li>
                            <li><a href="/amc/">AMC Service Provider</a></li>
                            <li><a href="/spareparts/">Spare Parts</a></li>
                            <li><a href="/generatorrentalhire/">Generator Rental & Hire</a></li>
                            <li><a href="/synchronizing/">Synchronizing Panel</a></li>
                            <li><a href="/amfpanel/">AMF Panel</a></li>
                            <li><a href="acousticenclosures">Acoustic Enclosures</a></li>
                        </ul>
                    </li>
                    <li><a href="/contactus/">Contact Us</a></li>
                </ul>
            </div>
        </div>
    </nav>

    {% block body %}
    {% endblock %}

    <footer class="text-center">
            <div class="container-fluid">
                <div class="row">
                    <div class="col-xs-offset-1 col-xs-10 col-md-offset-3 col-md-6">
                        <h4>Copyright &copy; Vasu Genset Pvt. Ltd.</h4>
                    </div>
                </div>
            </div>
    </footer>


</body>

    <!-- jQuery (necessary for Bootstrap's JavaScript plugins) -->
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
    <!-- Include all compiled plugins (below), or include individual files as needed -->
    <script src="{% static 'index/js/bootstrap.min.js' %}"></script>

    <script>
        $(document).ready(function () {
            $('.nav li').click(function(e) {

                $('.nav li').removeClass('active');

                var $this = $(this);
                if (!$this.hasClass('active')) {
                    $this.addClass('active');
                }
                //e.preventDefault();
            });
        });
    </script>



</html>

your code works but it will trigger x time in x-nested ul li (uncomment the line to see in the console what's happened when you click). 您的代码可以工作,但是会在x嵌套的ul中触发x时间(取消注释该行即可在控制台中查看单击时发生的情况)。 Depending on the behaviour you expect, just stop event propagation can do the trick. 根据您期望的行为,仅停止事件传播就可以解决问题。 (plus if (!$this.hasClass('active')) will always return true as you have just removed all class 'active' in all li contained in nav). (加上if (!$this.hasClass('active'))将始终返回true,因为您刚刚删除了nav中包含的所有li中的所有类'active'。

 $('.nav li').click(function(e) { //console.log(e.currentTarget,"//",e.target,"//",this); e.stopPropagation(); $('.nav li').removeClass('active'); $(this).addClass('active'); }); 
 .active{ background-color:red; } 
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <nav class="navbar navbar-default"> <div class="container"> <div class="navbar-header"> <a class="navbar-brand" href="#/">Vasu Genset Pvt. Ltd.</a> <button class="navbar-toggle collapsed" data-toggle="collapse" data-target="#mydropdown"> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button> </div> <div class="collapse navbar-collapse" id="mydropdown"> <ul class="nav navbar-nav navbar-right" id="navbar-change"> <li class="active"><a href="#/">Home</a></li> <li><a href="#/">About Us</a></li> <li class="dropdown"> <a href="#/" class="dropdown-toggle" data-toggle="dropdown">Products & Services <span class="caret"></span></a> <ul class="dropdown-menu"> <li><a href="#/">Generator Repair</a></li> <li><a href="#/">Generator Maintenance</a></li> <li><a href="#/">Alternator Repair & Maintenance</a></li> <li><a href="#/">AMC Service Provider</a></li> <li><a href="#/">Spare Parts</a></li> <li><a href="#/">Generator Rental & Hire</a></li> <li><a href="#/">Synchronizing Panel</a></li> <li><a href="#/">AMF Panel</a></li> <li><a href="#/">Acoustic Enclosures</a></li> </ul> </li> <li><a href="#/">Contact Us</a></li> </ul> </div> </div> </nav> 

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM