一聚教程网:一个值得你收藏的教程网站

热门教程

CSS让DIV固定位置 不随滚动条而滚动

时间:2022-06-25 10:10:10 编辑:袖梨 来源:一聚教程网

CSS怎么让DIV固定位置不随滚动条而滚动?本篇文章小编给大家带来Css div固定位置介绍,对此感兴趣的赶快来看看吧!

fixed元素的绝对位置是相对于HTML元素来说,滚动条是body元素的。

只有记住了这句话,才知为什么position:absolute;很多地方都给出了结果,但当时并未能解决。因为html被我设置position:relative。是上面这一句启发了我,最终才能够解决这个问题。我们拉动滚动条的时候,内容都会随着窗口滚动;这时滚动的是body。如果让绝对定位的父级元素定为body,刚我们需要固定的某个模块将会固定在网页的某个位置,而不是固定在窗口的某个位置(貌似在firefox中,html与body之间的介限并不明确?)。
我们需要做的是,让body保持其原有高度,让html只有一个窗口那么高。代码我们可以这样写:

css">html{overflow:hidden;} // 重要!
body{height:100%;overflow:auto;}

这时,html将只有一个窗口那么高,超过的,直接hide。而body会随高度自动变化。这时,我们可以利用绝对定位来定位我们想要固定在窗口某个位置的模块。假设我们要固定的内容在右上角,代码可以这样写:

html{overflow:hidden;}
body{height:100%;overflow:auto;}
#rightform form{position:absolute;right:30px;top50px;}

这样,窗口就固定在右上角了。而其他浏览器,我们可以用position:fixed;来解决固定的问题。其他浏览器完整的代码如下

#rightform {text-align:center;padding:50px;font:14px/22px Georgia, “Times New Roman”, Times, serif;background:#ffc;}
#rightform h1 {font-family:arial;background:#e8edef;line-margin-bottom:200px;}
#rightform p {line-height:1.5em;background:#ffdfff;padding:90px 0;}
#rightform form {background-color:#ddd;padding:10px 20px;border:1px solid #aaa;position:fixed;right:30px;top:120px;}

首先我们来看一段XHTML代码。

 
右侧主体内容

页面由左侧菜单和右侧主体内容构成,右侧内容可能会很多,会出现翻屏。现在是要无论页面怎么翻屏滚动,左侧的菜单始终在左侧。请看CSS解决方案。

#site_nav{position:fixed;  padding:6px 10px; height:100%;  
background:#ffc; overflow-y:auto;} 
#content{padding:10px 10px 10px 190px;}

我设置左侧div#site_nav的样式,将其位置固定,即position:fixed,并且设置固定宽度,高度为100%,为了区分右侧内容,我设置了背景颜色background:#ffc。

接着,我将内容部分div#content设置其padding值,注意关键是padding-left:190px,只有大于左侧菜单宽度的padding值,才能使右侧主体内容部分不会与左侧菜单重叠

完整实例





无标题文档






热门栏目