我用 #container
div 创建了一个简单的网站,它是两个 div 的父级: #left
和 #right
,通过使用 网格布局
有什么办法可以固定左栏吗?我希望左边的文本保留在其位置上,而右边的文本可以像现在一样滚动。将 position: fixed
添加到 #left
会破坏布局。
我知道这个问题已经解决了,但我希望有一种方法可以让它与网格布局一起工作。
谢谢。
body {
margin: 0 0 0 0;
}
#container {
display: grid;
grid-template-columns: 50% 50%;
}
.section {
padding: 5% 5% 5% 5%;
}
#left {
background-color: aquamarine;
}
#right {
background-color: beige;
}
<div id="container">
<div id="left" class="section">
<p>This should not scroll</p>
</div>
<div id="right" class="section">
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla aliquet consectetur purus nec volutpat. Donec vel libero nec est commodo facilisis vel et nisl. Praesent porta sed eros eu porta. Cras dolor nulla, ullamcorper et tincidunt quis, porta ut
tellus. Maecenas cursus libero sed accumsan luctus. Integer sed consequat ante. Morbi sit amet lectus tempor elit tempor cursus ut sed enim. Donec placerat bibendum volutpat.
</p>
<p>
Nunc sit amet eleifend sapien, sed tincidunt neque. Donec id sapien et nunc scelerisque iaculis dignissim nec mauris. Fusce at pretium nulla. Maecenas vel rutrum tellus, a viverra nunc. Aenean at arcu vitae dui faucibus dapibus. Vivamus hendrerit blandit
mollis. Aenean sit amet lectus a metus faucibus condimentum. Proin vel eros ut elit pharetra lacinia vitae eu orci. Etiam massa massa, aliquam at pulvinar ut, porttitor eu mauris. Ut in iaculis sapien.
</p>
<p>
In vitae rhoncus arcu. Maecenas elementum nunc quis magna finibus, vitae imperdiet diam pulvinar. Phasellus sit amet nibh eu massa facilisis luctus. Nulla ullamcorper sodales ante id vestibulum. Fusce felis nisi, lacinia sit amet mauris vel, euismod suscipit
neque. Mauris quis libero eget enim facilisis pharetra. Fusce non ligula auctor nunc pretium dignissim eget eget turpis. Nam ultricies dolor ac libero maximus vestibulum. Mauris et tortor vitae nisi ultrices vestibulum ac id mauris. Proin interdum
dapibus sollicitudin. Phasellus ultricies vulputate sem id hendrerit. Cras eget posuere nunc, in placerat velit. Pellentesque sed ante at elit ornare efficitur. Donec sed condimentum nisl. Curabitur dapibus leo id ligula dignissim pharetra.
</p>
</div>
</div>
原文由 MeLlamoPablo 发布,翻译遵循 CC BY-SA 4.0 许可协议
你写了:
如果您希望该元素保留为网格项,那么答案是“否”。
一旦元素具有
position: absolute
或position: fixed
( 这是一种绝对定位的形式,参考视口),它就会呈现出新的特征:从规格:
所以 网格项目 不能很好地与绝对定位一起工作。
但是,将
position: fixed
应用于 网格容器 不会有问题。考虑单独管理您的
#left
和#right
元素。#left
可以是固定位置的网格容器。#right
可以是另一个网格容器并保持流入。另外,顺便说一句,您已经为网格项目提供了基于百分比的填充:
将
margin
和padding
应用于网格项目(和弹性项目)时,最好远离百分比单位。浏览器可能会以不同方式计算这些值。