如果定位的父元素(包含position: relative
或position: absolute
)具有position: absolute
的子元素,那么子元素将在定位的父元素内绝对定位。
具有position: sticky
的子元素的行为方式相同 - 子元素将在定位的父元素内粘贴定位。
但是position: fixed
的子元素不会占据定位父级中的固定位置。
说明性示例:
.panel {
display: inline-block;
position: relative;
width: 240px;
height: 180px;
margin-right: 6px;
overflow-x: hidden;
overflow-y: auto;
}
header, footer {
display: block;
position: fixed;
left: 0;
width: 240px;
height: 24px;
background-color: rgb(255, 0, 0);
}
header {
top: 0;
}
footer {
bottom: 0;
}
.panel + .panel header,
.panel + .panel footer {
position: sticky;
}
header code {
padding-left: 6px;
font-weight: bold;
color: rgb(255, 255, 255);
}
<div class="panel">
<header><code>position: fixed</code></header>
<p>Alice was beginning to get very tired of sitting by her sister on the bank, and of having nothing to do: once or twice she had peeped into the book her sister was reading, but it had no pictures or conversations in it, `and what is the use of a book,' thought Alice `without pictures or conversation?'</p>
<p>So she was considering in her own mind (as well as she could, for the hot day made her feel very sleepy and stupid), whether the pleasure of making a daisy-chain would be worth the trouble of getting up and picking the daisies, when suddenly a White Rabbit with pink eyes ran close by her.</p>
<p>There was nothing so very remarkable in that; nor did Alice think it so very much out of the way to hear the Rabbit say to itself, `Oh dear! Oh dear! I shall be late!' (when she thought it over afterwards, it occurred to her that she ought to have wondered at this, but at the time it all seemed quite natural); but when the Rabbit actually took a watch out of its waistcoat-pocket, and looked at it, and then hurried on, Alice started to her feet, for it flashed across her mind that she had never before seen a rabbit with either a waistcoat-pocket, or a watch to take out of it, and burning with curiosity, she ran across the field after it, and fortunately was just in time to see it pop down a large rabbit-hole under the hedge.</p>
<footer></footer>
</div>
<div class="panel">
<header><code>position: sticky</code></header>
<p>Alice was beginning to get very tired of sitting by her sister on the bank, and of having nothing to do: once or twice she had peeped into the book her sister was reading, but it had no pictures or conversations in it, `and what is the use of a book,' thought Alice `without pictures or conversation?'</p>
<p>So she was considering in her own mind (as well as she could, for the hot day made her feel very sleepy and stupid), whether the pleasure of making a daisy-chain would be worth the trouble of getting up and picking the daisies, when suddenly a White Rabbit with pink eyes ran close by her.</p>
<p>There was nothing so very remarkable in that; nor did Alice think it so very much out of the way to hear the Rabbit say to itself, `Oh dear! Oh dear! I shall be late!' (when she thought it over afterwards, it occurred to her that she ought to have wondered at this, but at the time it all seemed quite natural); but when the Rabbit actually took a watch out of its waistcoat-pocket, and looked at it, and then hurried on, Alice started to her feet, for it flashed across her mind that she had never before seen a rabbit with either a waistcoat-pocket, or a watch to take out of it, and burning with curiosity, she ran across the field after it, and fortunately was just in time to see it pop down a large rabbit-hole under the hedge.</p>
<footer></footer>
</div>
javascript是解决这个问题的唯一方法吗?
或者是否有一种CSS方法可以使position: fixed
子元素在其定位的父元素中占据固定位置?
答案 0 :(得分:2)
根据specs,固定位置始终相对于视口。所以这是一个特色。
答案 1 :(得分:0)
这是一种javascript方法,它使页眉和页脚相对于可滚动父级采用虚假位置。
工作示例:
var panel = document.getElementsByClassName('panel')[0];
var panelHeader = panel.getElementsByTagName('header')[0];
var panelFooter = panel.getElementsByTagName('footer')[0];
function fixElements() {
var panelHeight = panel.clientHeight;
var panelFooterHeight = panelFooter.clientHeight;
panelHeader.style.top = panel.scrollTop + 'px';
panelFooter.style.top = panel.scrollTop + panelHeight - panelFooterHeight + 'px';
}
panel.addEventListener('scroll', fixElements, false);
.panel {
display: inline-block;
position: relative;
width: 240px;
height: 180px;
overflow-x: hidden;
overflow-y: auto;
}
header, footer {
display: block;
position: absolute;
left: 0;
width: 240px;
height: 24px;
background-color: rgb(255, 0, 0);
}
header {
top: 0;
}
footer {
top: 156px;
}
header code {
padding-left: 6px;
font-weight: bold;
color: rgb(255, 255, 255);
}
.panel p:first-of-type {
padding-top: 12px;
}
.panel p:last-of-type {
padding-bottom: 12px;
}
<div class="panel">
<header><code>position: faux-fixed</code></header>
<p>Alice was beginning to get very tired of sitting by her sister on the bank, and of having nothing to do: once or twice she had peeped into the book her sister was reading, but it had no pictures or conversations in it, `and what is the use of a book,' thought Alice `without pictures or conversation?'</p>
<p>So she was considering in her own mind (as well as she could, for the hot day made her feel very sleepy and stupid), whether the pleasure of making a daisy-chain would be worth the trouble of getting up and picking the daisies, when suddenly a White Rabbit with pink eyes ran close by her.</p>
<p>There was nothing so very remarkable in that; nor did Alice think it so very much out of the way to hear the Rabbit say to itself, `Oh dear! Oh dear! I shall be late!' (when she thought it over afterwards, it occurred to her that she ought to have wondered at this, but at the time it all seemed quite natural); but when the Rabbit actually took a watch out of its waistcoat-pocket, and looked at it, and then hurried on, Alice started to her feet, for it flashed across her mind that she had never before seen a rabbit with either a waistcoat-pocket, or a watch to take out of it, and burning with curiosity, she ran across the field after it, and fortunately was just in time to see it pop down a large rabbit-hole under the hedge.</p>
<footer></footer>
</div>