Bootstrap 自定义打开和关闭按钮汉堡菜单

时间:2021-07-26 15:47:20

标签: html css twitter-bootstrap

我正在使用 Bootstrap 构建一个汉堡包菜单。我想使用我自己的打开和关闭按钮。我已经成功地做到了这一点。但是我遇到了一个问题:c 汉堡包图标没有完全显示

代码如下:

<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.1/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-+0n0xVW2eSR5OomGNYDnhzAbDsOXxcvSN1TPprVMTNDbiYZCxYbOOl7+AMvyTG2x" crossorigin="anonymous">
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.6.0/js/bootstrap.bundle.min.js"></script>

<nav class="navbar navbar-light bg-light">
    
    <button class="navbar-toggler collapsed" type="button" data-toggle="collapse" data-target="#navbarsExampleDefault" aria-controls="navbarsExampleDefault" aria-expanded="false" aria-label="Toggle navigation">
       <span class="close" style="margin-left:20px><img src="images/mobile-menu-close.png" width="33"></span>
       <span class="navbar-toggler-icon"></span>
    </button>
    <div class="collapse navbar-collapse" id="navbarsExampleDefault">
        <ul class="navbar-nav" style>
            <li class="nav-item"><a href="" class="nav-link">Link</a></li>
            <li class="nav-item"><a href="" class="nav-link">Link</a></li>
            <li class="nav-item"><a href="" class="nav-link">Link</a></li>
        </ul>
    </div>
</nav>

CSS:

<style type="text/css">

.navbar-toggler>.close {
    display:inline;

}
.navbar-toggler.collapsed>.close, .navbar-toggler:not(.collapsed)>.navbar-toggler-icon {
    display:none;
}
.navbar-light .navbar-toggler-icon{
    background-image: url(images/mobile-menu-open.png)!important;
    background-size: 33px 33px;
    background-repeat:no-repeat;
    margin-left: 20px;
}

.navbar-toggler {
    border: none;
    background-color: transparent;
}

.navbar-toggler:focus,
.navbar-toggler:active,
.navbar-toggler-icon:focus {
    outline: none;
    box-shadow: none;
}

.navbar{
    width: 200px;
    background-color: transparent!important;
}
.navbar-collapse{
    background-color: gray;
}

</style>

以下是我使用的图片: hamburger close icon 有什么想法吗?

这是一张破损的汉堡菜单的图片: broken hamburger

1 个答案:

答案 0 :(得分:0)

您在这里缺少一个“:

style="margin-left:20px">

与其将图像添加到关闭跨度,不如使用 Javascript 更改类并将您的 css 添加到该类中,以便汉堡在命中时变为 x。

退房:Bootstrap mobile menu icon change to x close