展会信息港展会大全

CSS让DIV固定位置 不随滚动条而滚动
来源:互联网   发布日期:2016-03-25 16:27:52   浏览:2983次  

导读:在Css div固定方面我们可以用position:fixed来实现,下面我来给各位同学详细介绍在各种浏览器中position:fixed用法与兼容解决办法。fixed元素的绝对位置是相对...

在Css div固定方面我们可以用position:fixed来实现,下面我来给各位同学详细介绍在各种浏览器中position:fixed用法与兼容解决办法。

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

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

我们需要做的是,让body保持其原有高度,让html只有一个窗口那么高。代码我们可以这样写:

代码如下

复制代码

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;height:1200px;background:#ffc;}

#rightform h1 {font-family:arial;background:#e8edef;height:300px;line-height:300px;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代码。

代码如下

复制代码

<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值,才能使右侧主体内容部分不会与左侧菜单重叠

完整实例

代码如下

复制代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>无标题文档</title>

<style type="text/css">

*{margin:0; padding:0}

body{font-family:Arial, Helvetica, sans-serif; font-size:14px; color:#747d67; background:#fff}

a{color:#528036; text-decoration:none}

a:hover{color:#000; text-decoration:none}

ul{list-style:none}

h1{font-size:16px}

.clear{clear:both}

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

#site_nav ul{margin:2px}

#site_nav ul li{line-height:22px}

#site_nav ul li ul{padding-left:12px}

#content{padding: 10px 10px 10px 190px;}

#content ul{margin:10px auto}

</style>

</head>

<body>

<div id="site_nav">

<h1>歌手库</h1>

<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">

<ul>

<li><a href="#">A ONE</a></li>

<li><a href="#">A-Z乐队</a></li>

<li><a href="#">A.J.Alex</a></li>

<li><a href="#">ADO</a></li>

<li><a href="#">Airbag</a></li>

<li><a href="#">Ak-47</a></li>

<li><a href="#">阿佳组合</a></li>

<li><a href="#">阿莱乐队</a></li>

<li><a href="#">阿里郎</a></li>

<li><a href="#">阿里山桃花</a></li>

<li><a href="#">阿吟琴</a></li>

<li><a href="#">阿猫阿狗</a></li>

<li><a href="#">阿妹妹</a></li>

<li><a href="#">爱库乐团</a></li>

<li><a href="#">爱朵女孩</a></li>

<li><a href="#">安琪儿</a></li>

<li><a href="#">爱乐团</a></li>

<li><a href="#">哎吆乐队</a></li>

<li><a href="#">城市少女</a></li>

</ul>

<ul>

<li><a href="#">B.A.D</a></li>

<li><a href="#">Beyond</a></li>

<li><a href="#">BOBO组合</a></li>

<li><a href="#">八十八颗芭乐籽</a></li>

<li><a href="#">八只眼组合</a></li>

<li><a href="#">办桌二人组</a></li>

<li><a href="#">棒棒堂</a></li>

<li><a href="#">北京天使合唱团</a></li>

<li><a href="#">不复之血乐队</a></li>

<li><a href="#">薄荷可乐三人组</a></li>

<li><a href="#">病蛹乐队</a></li>

<li><a href="#">冰火组合</a></li>

<li><a href="#">病医生乐队</a></li>

<li><a href="#">北京中央人</a></li>

<li><a href="#">布衣乐队</a></li>

</ul>

<ul>

<li><a href="#">A ONE</a></li>

<li><a href="#">A-Z乐队</a></li>

<li><a href="#">A.J.Alex</a></li>

<li><a href="#">ADO</a></li>

<li><a href="#">Airbag</a></li>

<li><a href="#">Ak-47</a></li>

<li><a href="#">阿佳组合</a></li>

<li><a href="#">阿莱乐队</a></li>

<li><a href="#">阿里郎</a></li>

<li><a href="#">阿里山桃花</a></li>

<li><a href="#">阿吟琴</a></li>

<li><a href="#">阿猫阿狗</a></li>

<li><a href="#">阿妹妹</a></li>

<li><a href="#">爱库乐团</a></li>

<li><a href="#">爱朵女孩</a></li>

<li><a href="#">安琪儿</a></li>

<li><a href="#">爱乐团</a></li>

<li><a href="#">哎吆乐队</a></li>

<li><a href="#">城市少女</a></li>

</ul>

<ul>

<li><a href="#">A ONE</a></li>

<li><a href="#">A-Z乐队</a></li>

<li><a href="#">A.J.Alex</a></li>

<li><a href="#">ADO</a></li>

<li><a href="#">Airbag</a></li>

<li><a href="#">Ak-47</a></li>

<li><a href="#">阿佳组合</a></li>

<li><a href="#">阿莱乐队</a></li>

<li><a href="#">阿里郎</a></li>

<li><a href="#">阿里山桃花</a></li>

<li><a href="#">阿吟琴</a></li>

<li><a href="#">阿猫阿狗</a></li>

<li><a href="#">阿妹妹</a></li>

<li><a href="#">爱库乐团</a></li>

<li><a href="#">爱朵女孩</a></li>

<li><a href="#">安琪儿</a></li>

<li><a href="#">爱乐团</a></li>

<li><a href="#">哎吆乐队</a></li>

<li><a href="#">城市少女</a></li>

</ul>

<ul>

<li><a href="#">A ONE</a></li>

<li><a href="#">A-Z乐队</a></li>

<li><a href="#">A.J.Alex</a></li>

<li><a href="#">ADO</a></li>

<li><a href="#">Airbag</a></li>

<li><a href="#">Ak-47</a></li>

<li><a href="#">阿佳组合</a></li>

<li><a href="#">阿莱乐队</a></li>

<li><a href="#">阿里郎</a></li>

<li><a href="#">阿里山桃花</a></li>

<li><a href="#">阿吟琴</a></li>

<li><a href="#">阿猫阿狗</a></li>

<li><a href="#">阿妹妹</a></li>

<li><a href="#">爱库乐团</a></li>

<li><a href="#">爱朵女孩</a></li>

<li><a href="#">安琪儿</a></li>

<li><a href="#">爱乐团</a></li>

<li><a href="#">哎吆乐队</a></li>

<li><a href="#">城市少女</a></li>

</ul>

<ul>

<li><a href="#">A ONE</a></li>

<li><a href="#">A-Z乐队</a></li>

<li><a href="#">A.J.Alex</a></li>

<li><a href="#">ADO</a></li>

<li><a href="#">Airbag</a></li>

<li><a href="#">Ak-47</a></li>

<li><a href="#">阿佳组合</a></li>

<li><a href="#">阿莱乐队</a></li>

<li><a href="#">阿里郎</a></li>

<li><a href="#">阿里山桃花</a></li>

<li><a href="#">阿吟琴</a></li>

<li><a href="#">阿猫阿狗</a></li>

<li><a href="#">阿妹妹</a></li>

<li><a href="#">爱库乐团</a></li>

<li><a href="#">爱朵女孩</a></li>

<li><a href="#">安琪儿</a></li>

<li><a href="#">爱乐团</a></li>

<li><a href="#">哎吆乐队</a></li>

<li><a href="#">城市少女</a></li>

</ul>

</div>

</body>

</html>

赞助本站

人工智能实验室

相关热词: 开发 编程 android

AiLab云推荐
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港