javascript 右对齐而不溢出屏幕CSS

6jjcrrmo  于 2022-12-17  发布在  Java
关注(0)|答案(2)|浏览(150)

好的,我正在尝试做一个菜单。有一个侧菜单,将有某些元素和顶部菜单,将有其他元素。我有一个问题,当我应用positio:absolute,然后一个right:0 px来对齐图标和名称的权利,它离开屏幕,因为我的身体有一个margin-left:280像素

let menuToggleButton = document.getElementById('menu_toggle_button');
let side_menu = document.getElementById('side_menu');
let body = document.getElementById('body');

menuToggleButton.addEventListener('click', function() {
    side_menu.classList.toggle('resize-side-menu');
    body.classList.toggle('resize-body');
});
*{
    margin: 0px;
    padding: 0px;
}
body{
    display: flex;
}
.side-menu{
    position: fixed;
    display: inline-flex;
    background: #ff000061;
    width: 280px;
    height: 100vh;
    transition: .5s;
}
.resize-side-menu{
    width: 50px;
    transition: .5s;
}
.body{
    display: inline-flex;
    width: 100%;
    height: 60px;
    margin-left: 280px;
    background: blue;
    height: 2000px;
    transition: .5s;
}
.resize-body{
    margin-left: 50px;
    transition: .5s;
}
.body .content-body{
    display: block;
    width: 100%;
    height: 100%;   
}
.body .content-body .header{
    width: 100%;
    height: 50px;
    display: block;
    position: fixed;
}
.content-items-header{
    display: flex;
    align-items: center;
    background: brown;
    position: relative;
    height: 50px;
}
.body .content-body .header .content-items-header .content-search-input{
    background: white;
    color: rgb(0, 0, 0);
    border: 2px solid blue;
}
.body .content-body .header .content-items-header .icons-content{
    position:absolute;
    right:0px;
}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="style.css">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.8.0/css/all.min.css">
</head>
<body>
    <div class="side-menu" id="side_menu">
        
    </div>
    <div class="body" id="body">
        <div class="content-body">
            <div class="header">
                <div class="content-items-header">
                    <button class="fad fa-bars" id="menu_toggle_button">open</button>
                    <div class="content-search-input">
                        <input type="text" class="search" id="search">
                        <i class="fad fa-search"></i>
                    </div>
                    <div class="icons-content">
                        <i class="fas fa-bell"></i>
                        <i class="fas fa-envelope"></i>
                        <i class="fas fa-cog"></i>
                    <img src="brain.jpg" alt="" height="35px" width="35px">
                    <span>Aldahir Ruiz Valdez</span>
                    </div>

                </div>
            </div>
            <div class="workspace">
    
            </div>
        </div>
    </div>
    <script src="main.js"></script>
</body>
</html>

我需要它们始终向右对齐,但不离开屏幕

m1m5dgzv

m1m5dgzv1#

尝试从.header中删除position: fixed;

bgtovc5b

bgtovc5b2#

尝试overflow: hidden;overflow: auto取决于你想要到实现. overflow: hidden;将隐藏所有这溢出,并且overflow: auto将添加一个滚动条如果它是需要的.

相关问题