使用CSS让DIV固定位置

原创文章 作者:月光光 2011年01月05日 13:01helloweba.com 标签:CSS3 

本文将讲述如何使用CSS让DIV固定在页面的左侧,而页面右侧内容滚动时,左侧位置不随页面滚动。这种效果在很多地方得到应用。

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

<div id="site_nav">
    <h3>歌手库</h3>
    <ul>
      <li><a href="#">华语</a>
          <ul>
             <li><a href="#">女歌手</a></li>
             <li><a href="#">男歌手</a></li>
             <li><a href="#">乐队组合</a></li>
          </ul>
      </li>
      <li><a href="#">欧美</a></li>
      <li><a href="#">日韩</a></li>
      <li><a href="#">其他</a></li>
    </ul>
</div>
<div id="content">
右侧主体内容
</div>

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

#site_nav{position:fixed; width:160px; 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值,才能使右侧主体内容部分不会与左侧菜单重叠。请看演示DEMO

声明:本文为原创文章,helloweba.net和作者拥有版权,如需转载,请注明来源于helloweba.net并保留原文链接:https://www.helloweba.net/javascript/99.html

6条评论

  • 这个文本编辑器,看着确实不错,特别是可以插入非一般的表情,是我最喜欢的

  • 或 DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3***/TR/xhtml1/DTD/xhtml1-transitional.dtd"

  • 不兼容加上这个试试:
    <html xmlns="http://www.w3***/1999/xhtml">

  • 这个不错哦
    http://ilikecss.com/blog/fixed-sidenav-layout/

  • 是的,ie6、ie7

  • 老大,这个不兼容!!!!