【问题标题】:Bootstrap mobile menu wont stay openBootstrap 移动菜单不会保持打开状态
【发布时间】:2017-05-15 22:26:29
【问题描述】:

这里是第一个问题,感谢您的耐心等待。

我寻找了一个类似的问题,但很惊讶我没有诚实地找到一个。

我也学到了足够的知识来为此创建一个小提琴。你可以在这里看到它

https://jsfiddle.net/jhallwebdev/gm6r6mLu/5/

HTML

<body>
<div class="container-fluid">
    <div class="row yellow container-fluid">    <!-- YELLOW NAV ROW -->
        <div class="col-lg-1 col-md-2 col-sm-2 col-xs-2">
            <div>
                <img src="logo.jpeg" alt="logo" title="logo" width="100px" height="100px" class="my-image">
            </div>
        </div>
        <div class="col-lg-5 col-md-7 col-sm-7 col-xs-7">
            <div class="jer-margin-left">
                <div class="header-title">My Bootstrap Site</div>
                <div class="header-slogan">And its navbar problem...</div>
            </div>
        </div>
        <div class="col-lg-6 col-md-3 col-sm-3 col-xs-3">
            <div>
                <nav class="navbar navbar-default">
                    <div class="container-fluid">
                        <div class="navbar-header">
                            <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
                                <span class="sr-only">Toggle navigation</span>
                                <span class="icon-bar"></span>
                                <span class="icon-bar"></span>
                                <span class="icon-bar"></span>
                            </button>
                        </div>
                        <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
                            <ul class="nav navbar-nav jer-nav">
                                <li class="jer-active"><a href="#">HOME <span class="sr-only">(current)</span></a></li>
                                <li><a href="#">ABOUT US</a></li>
                                <li><a href="#">SERVICES</a></li>
                                <li><a href="#">FORMS</a></li>
                                <li><a href="#">CONTACT US</a></li>
                            </ul>
                        </div><!-- /.navbar-collapse -->
                    </div><!-- /.container-fluid -->
                </nav>
            </div>
        </div>
    </div>  <!-- END YELLOW NAV ROW -->
</div>  <!-- END CONTAINER -->  

CSS

[hidden] {
  display: none;
}

* {
    box-sizing: border-box;
}

.yellow {
    background-color: rgb(253, 232, 104);
    width: 100%;
}

.my-image {
    margin: 10px;
}

.jer-margin-left {
    margin-left: 15px;
}

.header-title {
    color: #000;
    font-family: Merriweather;
    font-style: italic;
    font-size: 30px;
    margin: 20px 0 0 0;
}

.header-slogan {
    color: #000;
    font-family: Merriweather;
    font-style: italic;
    font-size: 22px;
}

.no-left-margin {
    margin-left: -70px;
}

.navbar-default {
    background-color: rgb(253, 232, 104);
    border-color: rgb(253, 232, 104);
    padding-top: 20px;
}

.jer-nav {
    padding-top: 10px;
    padding-bottom: 10px;
    color: #000;
    text-align: center;
    font-family: Montserrat;
    font-size: 16px;
    text-transform: uppercase;
    float: right;
}

.navbar-default .navbar-nav>li>a {
    color: #000;
}

.navbar-default .navbar-nav>li>a:hover {
    color: white;
}

.container-fluid {
    padding-right: 0;
    padding-left: 0;
    margin: 0;
}

.jer-active {
    border: silver solid 1px;
    background-color: rgb(253, 232, 104);
}

@media (max-width: 420px) {
    .jer-margin-left {
        margin-left: 65px;
    }
}

@media (max-width: 600px) {
    .header-title {
        font-size: 22px;
    }

    .header-slogan {
        font-size: 15px;
    }

    .jer-margin-left {
        margin-left: 45px;
    }
}

@media (max-width: 1200px) {
    .ph-float-right {
        float: none;
        margin-right: 0;
    }
    .navbar-header {
        float: none;
    }
    .navbar-toggle {
        display: block;
    }
    .navbar-collapse {
        border-top: 1px solid transparent;
        box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
    }
    .navbar-collapse.collapse {
        display: none!important;
    }
    .navbar-nav {
        float: none!important;
        margin: 7.5px -15px;
    }
    .navbar-nav>li {
        float: none;
    }
    .navbar-nav>li>a {
        padding-top: 10px;
        padding-bottom: 10px;
    }
}

减小输出窗口的大小以强制移动菜单。 (而不是水平文本菜单)

问题 1:要打开移动菜单,我需要单击它两次。这是第一个问题。

问题 2:它不会保持打开状态。

在设置小提琴时,我开始相信这是一个 css 问题,因为当所有 css 都被剥离时,它可以按预期工作。如果我正确设置小提琴,我的 css 在 css 窗口中,并且股票引导 css 通过 jsfiddle 中的外部资源选项进入。

非常感谢您的关注。

【问题讨论】:

    标签: css twitter-bootstrap mobile navbar


    【解决方案1】:

    这是告诉浏览器将其从视图中删除,您应该将其删除:

    .navbar-collapse.collapse {
        display: none!important;
    }
    

    Bootstrap 在任何 data-toggle="collapse" 元素上使用 class="collapse"class="collapse show"

    您已经覆盖了 class="collapse show" 显示元素的能力,因为您已经创建了自己的样式 !important,还因为您通过在选择器中引用两个类来匹配引导选择器的特殊性。

    之所以必须“单击两次”是因为 bootstrap 添加了另一个类'collapsing' 来显示过渡,并且当元素为'collapse show collapsing' 时它是可见的,但是当它只有'collapse collapsing' 时它不是。

    【讨论】:

    • 我在这里的任何地方都看不到 collapse-show 类。应该是吗?我直接从引导站点复制了导航栏。然后删除了我不需要的部分。我没有删除任何课程。
    • 不,这些类是由引导程序的 JavaScript 添加到元素中的。 (v4-alpha.getbootstrap.com/components/collapse)
    • 当我删除它时,会发生相反的情况。菜单默认打开。当我点击关闭它时,它会重新打开。
    • @JeremyHall 嗯,当我对你的小提琴进行更改时,我没有得到那种行为:jsfiddle.net/t7ou9to4/1
    • 删除建议的代码和另一部分后,我能够让它正常工作。不过我不记得第二张是什么了。我知道这没有帮助。不过,我确实让它正常工作。谢谢。
    【解决方案2】:

    查看fiddler后,通过删除

        .navbar-collapse.collapse {
            display: none!important;
        }
    

    解决了问题。

    在css中删除@media (max-width: 1200px)上面的代码

    我无法重现您的第一期。

    更新 我不确定你删除了什么。这是更新后的代码。

    [hidden] {
      display: none;
    }
    
    * {
        box-sizing: border-box;
    }
    
    .yellow {
        background-color: rgb(253, 232, 104);
        width: 100%;
    }
    
    .my-image {
        margin: 10px;
    }
    
    .jer-margin-left {
        margin-left: 15px;
    }
    
    .header-title {
        color: #000;
        font-family: Merriweather;
        font-style: italic;
        font-size: 30px;
        margin: 20px 0 0 0;
    }
    
    .header-slogan {
        color: #000;
        font-family: Merriweather;
        font-style: italic;
        font-size: 22px;
    }
    
    .no-left-margin {
        margin-left: -70px;
    }
    
    .navbar-default {
        background-color: rgb(253, 232, 104);
        border-color: rgb(253, 232, 104);
        padding-top: 20px;
    }
    
    .jer-nav {
        padding-top: 10px;
        padding-bottom: 10px;
        color: #000;
        text-align: center;
        font-family: Montserrat;
        font-size: 16px;
        text-transform: uppercase;
        float: right;
    }
    
    .navbar-default .navbar-nav>li>a {
        color: #000;
    }
    
    .navbar-default .navbar-nav>li>a:hover {
        color: white;
    }
    
    .container-fluid {
        padding-right: 0;
        padding-left: 0;
        margin: 0;
    }
    
    .jer-active {
        border: silver solid 1px;
        background-color: rgb(253, 232, 104);
    }
    
    @media (max-width: 420px) {
        .jer-margin-left {
            margin-left: 65px;
        }
    }
    
    @media (max-width: 600px) {
        .header-title {
            font-size: 22px;
        }
    
        .header-slogan {
            font-size: 15px;
        }
    
        .jer-margin-left {
            margin-left: 45px;
        }
    }
    
    @media (max-width: 1200px) {
        .ph-float-right {
            float: none;
            margin-right: 0;
        }
        .navbar-header {
            float: none;
        }
        .navbar-toggle {
            display: block;
        }
        .navbar-collapse {
            border-top: 1px solid transparent;
            box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
        }
    
        .navbar-nav {
            float: none!important;
            margin: 7.5px -15px;
        }
        .navbar-nav>li {
            float: none;
        }
        .navbar-nav>li>a {
            padding-top: 10px;
            padding-bottom: 10px;
        }
    }
    

    【讨论】:

    • 当我删除该部分时,移动菜单将永久打开。我不希望它默认打开。如果我单击它关闭,它会立即重新打开。就像之前发生的事情相反。
    • 删除建议的代码和另一部分后,我能够让它正常工作。不过我不记得第二张是什么了。我知道这没有帮助。不过,我确实让它正常工作。谢谢。
    【解决方案3】:

    也检查一下 您的 html 链接中有引导 js 吗?

    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
    

    【讨论】:

    • 是的。 bootstrap.min.js 在 jsfiddle 页面的外部资源中
    • 对不起,我在检查后看到了 - 上面的解决方案是完全正确的。一般来说,我的做法是不在我自己的 css 文件中使用引导类。
    【解决方案4】:

    我通过确保我拥有相同版本的 boostrap.cssbootstrap.js 并确保我在 bootstrap.js 之前加载 jquery 来解决此问题

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-01-11
      • 2019-09-15
      • 1970-01-01
      • 2011-11-05
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多