首页 > 解决方案 > 基本响应式导航上的徽标浮动

问题描述

我试图将我的图像徽标放在右上角(半语言问题),但是当我在 CSS 中添加" float: right"到我的.logo类时,它混合了我的 JavaScript 函数并使导航栏看起来很糟糕。我还没有上传我的图片,但任何其他汉堡菜单图标和徽标都适合。

let mainNav = document.getElementById('js-menu');
let navBarToggle = document.getElementById('js-navbar-toggle');

navBarToggle.addEventListener('click', function () {
mainNav.classList.toggle('active');
});
* {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
}
body {
    font-family: 'Josefin Sans', sans-serif;
}
.navbar {
    background-image: url("bg-mob.png");
    background-size: 100vw;
    font-size: 18px;
    /*background-image: linear-gradient(260deg, #2376ae 0%, #c16ecf   100%);*/
    border: 1px solid rgba(0, 0, 0, 0.2);
    padding-bottom: 10px;
}
.main-nav {
    list-style-type: none;
    display: none;
}
.nav-links, .logo {
    text-decoration: none;
    color: rgba(255, 255, 255, 0.7);

}


.main-nav li {
    text-align: center;
    margin: 15px auto;


}
.logo {
    display: inline-block;
    font-size: 22px;
    margin-top: 10px;
    margin-left: 20px;
    /*margin-right: auto;*/


}
.logo img {
    width: 150px;
/*background-color: white;*/
}
.navbar-toggle {
    position: absolute;
    top: 15px;
    left: 20px;
    cursor: pointer;
    color: rgba(255,255,255,0.8);
    font-size: 24px;
}
.active {
    display: block;
}
<nav class="navbar">
        <span class="navbar-toggle" id="js-navbar-toggle">
            <img src="https://via.placeholder.com/50" alt="">
        </span>
    <a href="#" class="logo"><img src="https://via.placeholder.com/150/0000FF"></a>
    <ul class="main-nav" id="js-menu">
        <li>
            <a href="#" class="nav-links">Home</a>
        </li>
        <li>
            <a href="#" class="nav-links">Products</a>
        </li>
        <li>
            <a href="#" class="nav-links">About Us</a>
        </li>
        <li>
            <a href="#" class="nav-links">Contact Us</a>
        </li>
        <li>
            <a href="#" class="nav-links">Blog</a>
        </li>
    </ul>
</nav>

标签: javascripthtmlcssreactjsweb

解决方案


您可以text-align: right;使用.navbar

let mainNav = document.getElementById('js-menu');
let navBarToggle = document.getElementById('js-navbar-toggle');

navBarToggle.addEventListener('click', function () {
mainNav.classList.toggle('active');
});
* {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
}
body {
    font-family: 'Josefin Sans', sans-serif;
}
.navbar {
    background-image: url("bg-mob.png");
    background-image: url("https://lh3.googleusercontent.com/IlhDxQVsR17dwwER5xYZJej867KrdSx0K5eyRP2RFP4eQJMD2pi0ZGBhrMOcajBUP9M54lpmIr90JecPUFGPaRe3sDZ82RvHBSw1rw-YJvQs7J8K3g=w1024-h683-n-l50-sg-rj");
    background-size: 100vw;
    font-size: 18px;
    /*background-image: linear-gradient(260deg, #2376ae 0%, #c16ecf   100%);*/
    border: 1px solid rgba(0, 0, 0, 0.2);
    padding-bottom: 10px;
    text-align: right; /* added */
}
.main-nav {
    list-style-type: none;
    display: none;
}
.nav-links, .logo {
    text-decoration: none;
    color: rgba(255, 255, 255, 0.7);

}


.main-nav li {
    text-align: center;
    margin: 15px auto;


}
.logo {
    display: inline-block;
    font-size: 22px;
    margin-top: 10px;
    margin-left: 20px;
    /*margin-right: auto;*/


}
.logo img {
    width: 150px;
/*background-color: white;*/
}
.navbar-toggle {
    position: absolute;
    top: 15px;
    left: 20px;
    cursor: pointer;
    color: rgba(255,255,255,0.8);
    font-size: 24px;
}
.active {
    display: block;
}
<nav class="navbar">
        <span class="navbar-toggle" id="js-navbar-toggle">
            <img src="https://lh3.googleusercontent.com/taykG37GWDgY-FGkdogDvsHSJMUGRMvkuVRT6yR-5UNkKvGRKeRlpGYXlslocOcS0txlfUdGW59JGtzADknxbMqnh6AtVCv9EXyB8nHp80YsRNA0Yw=w24-h16-n-l50-sg-rj" alt="">
        </span>
    <a href="#" class="logo"><img src="https://lh3.googleusercontent.com/taykG37GWDgY-FGkdogDvsHSJMUGRMvkuVRT6yR-5UNkKvGRKeRlpGYXlslocOcS0txlfUdGW59JGtzADknxbMqnh6AtVCv9EXyB8nHp80YsRNA0Yw=w150-h100-n-l50-sg-rj"></a>
    <ul class="main-nav" id="js-menu">
        <li>
            <a href="#" class="nav-links">Home</a>
        </li>
        <li>
            <a href="#" class="nav-links">Products</a>
        </li>
        <li>
            <a href="#" class="nav-links">About Us</a>
        </li>
        <li>
            <a href="#" class="nav-links">Contact Us</a>
        </li>
        <li>
            <a href="#" class="nav-links">Blog</a>
        </li>
    </ul>
</nav>


推荐阅读