首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Bootstrap4 scroll spy -主动到家长李

Bootstrap4 scroll spy -主动到家长李
EN

Stack Overflow用户
提问于 2017-11-24 21:47:48
回答 2查看 1.4K关注 0票数 1

我有这样的bootstrap4菜单:

代码语言:javascript
复制
<ul class="navbar-nav ml-auto">
<li class="nav-item"><a class="nav-link" href="#introduction">INTRODUKTION <span class="sr-only">(current)</span></a></li>
</ul>

默认scroll spy将active添加到nav-link (a)我需要更改它,因为我的active应该在nav-item (li)之后。我可以这样做吗?

你可以在这里看到这个:Example

当我点击的时候,一切都正常--但是在scroll - active上是一个href。

EN

回答 2

Stack Overflow用户

发布于 2017-11-24 22:07:20

默认情况下,.active类将仅添加到锚定标记。

根据您的需求尝试如下所示

代码语言:javascript
复制
$('[data-spy="scroll"]').on('activate.bs.scrollspy', function () {
  $(".navbar-nav .active").removeClass("active").parent().addClass("active");
})

添加属性data-spy="scroll"

在带有id="introduction"的部分的父级<div class="container">

喜欢

<div class="container" data-spy="scroll">

票数 2
EN

Stack Overflow用户

发布于 2017-11-24 22:33:17

我找到了解决方案。我只需要添加新的事件(cssClassChanged) -和工作!

代码语言:javascript
复制
(function(){
    // Your base, I'm in it!
    var originalAddClassMethod = jQuery.fn.addClass;

    jQuery.fn.addClass = function(){
        // Execute the original method.
        var result = originalAddClassMethod.apply( this, arguments );

        // trigger a custom event
        jQuery(this).trigger('cssClassChanged');

        // return the original result
        return result;
    }
})();

然后

代码语言:javascript
复制
$(".nav-link").bind('cssClassChanged' , function(e) {
        $(".nav-item").each( function() {
            if( $(this).hasClass("active") == true ) {
                $(this).removeClass("active");
            }
        });

        $(this).removeClass("active").parent().addClass("active");
    });
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47474657

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档