要css 底部固定需要两部分代码:html代码、css代码
1、html代码:
<body>
<div class='header'></div>
<div class='container'></div>
<div class='footer'></div>
</body>
2、css代码:
.container{ padding-bottom:30px/*需要 >= footer的height值*/}
.footer{ height:30pxposition:fixed bottom:0px z-index:-1}
扩展资料:
HTML代码使用规范问题:
1、格式问题
在代码视图中编写代码,一定要规范的格式,不要把代码全部都写到一块,这样不仅影响效率,更加影响视觉,当出现问题的时候往往很难找到原因所在,比如,我在编写HTML标签的时候总是每个标签都顶格写,结果今天在实验的时候,出现了错误,自己看着自己的代码找问题都想着急,最后根据嵌套的层数找到了原因,缺少了结束标签 导致的严重错误,所以谨记要把代码格式写规范;
2、布局问题:
在设计网页时,应该首先构造好网页的整个框架,然后对每个框架逐一进行完善,这样当那个部分出现问题的时候,我们就可以单独找到那个模块进行修改,例如我们刚刚学到的div+css这一部分的时候,应该先创建一个总的容器,然后在容器中逐一添加登录、导航、广告展示、主要内容、版权信息等各个模块,设置好各自的css样式,然后 再进行进一步的细化。
在这样的设计中,如果不先设计好总的结构,div的位置就会错乱,那样就不能很清晰地找到发生状况的原因。
3、输入问题:
一定要正确输入标签。输入标签时,不要输入多余的空格,否则浏览器可能无法识别这个标签,导致无法正确地显示信息。各种符号一定要在英文状态下输入,否则不会 显示正确的效果。源代码不区分大小写。
4、属性设置问题:
相应的标签对应着自己的属性,因为各个标签对应的属性实在是太多了,很容易混淆,如果我们想给某个标签内的内容设置相应的属性,我们必须在该标签内找到相应的 属性方法进行设置,比如将<table>的宽度设置为700、边框宽度设置为1、单元格间距为0,相应的代码设置是:<table width="700" border="1" cellspacing="0" >;
5、引用问题:
当我们在外部设置了css样式,并且要引用这个样式表时,我们必须要在<head></head>标签内添加<link>标签,如外部样式表为style.css,那么我们需要在head标签中添加的是<link href="css/style.css" rel="stylesheet" type="text/css"/>,首先href是引入样式的地址必不可少,rel定义了文档与链接的关系,stylesheet是定义一个外部加载样式表。
参考资料:百度百科——HTML代码
可用的方法比较多,比较常见的是使用CSS。
1、使用CSS
CSS让DIV固定位置不随滚动条而滚动,fixed元素的绝对位置是相对于HTML元素来说,滚动条是body元素的。
(1)我们需要做的是,让body保持其原有高度,让html只有一个窗口那么高。代码我们可以这样写:
html{overflow:hidden}
body{height:100%overflow:auto}
(2)我们可以利用绝对定位来定位我们想要固定在窗口某个位置的模块。假设我们要固定的内容在右上。
html{overflow:hidden}
body{height:100%overflow:auto}
#rightformform{position:absoluteright:30pxtop50px}
(3)页面由左侧菜单和右侧主体内容构成,右侧内容可能会很多,会出现翻屏。现在是要无论页面怎么翻屏滚动,左侧的菜单始终在左侧。请看CSS解决方案。
#site_nav{position:fixedwidth:160pxpadding:6px10pxheight:100%
background:#ffcoverflow-y:auto}
#content{padding:10px10px10px190px}
(4)我设置左侧div#site_nav的样式,将其位置固定,即position:fixed,并且设置固定宽度,高度为100%,为了区分右侧内容,我设置了背景颜色background:#ffc。
接着,我将内容部分div#content设置其padding值,注意关键是padding-left:190px,只有大于左侧菜单宽度的padding值,才能使右侧主体内容部分不会与左侧菜单重叠。
2、不使用JS:
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<metahttp-equiv="Content-Type"content="text/htmlcharset=utf-8"/>
<title>无标题文档</title>
<styletype="text/css">
ul{
margin:0
padding:0}
li{
list-style-type:nonefloat:leftmargin-left:10pxline-height:30px}
</style>
</head>
<body>
<divstyle="width:100%height:30pxbackground-color:#093position:fixedleft:0pxtop:0px">
<ul>
<li>sd</li>
<li>dsda</li>
<li>dsa</li>
</ul>
</div>
<divstyle="height:10000pxborder:1pxsolidred"></div>
<divstyle="width:100%height:30pxbackground-color:#093position:fixedleft:0pxbottom:0"></div>
</body>
</html>
3、<html>
<head>
<title></title>
<style type="text/css">
html,body {
overflow:hidden
margin:0px
width:100%
height:100%
}
.virtual_body {
width:100%
height:100%
overflow-y:scroll
overflow-x:auto
}
.fixed_div {
position:absolute
z-index:2008
bottom:20px
left:40px
width:800px
height:40px
border:1px solid red
background:#e5e5e5
}
</style>
</head>
<body>
<div class="fixed_div">I am still here!</div>
<div class="virtual_body">
<div style="height:888px">
I am content !
</div>
</div>
分析:
1、html,body:将默认可能会随机出现的滚动条,完全地隐藏了,这样不管您放了啥内容,它们都不会出来了。
2、.virtual_body:顾名思义,就是一个假的body了,它被设置为长宽都为100%的,意思就是它利用了所有可视的浏览器窗体显示所有的内容,并垂直允许出现滚动条。
3、.fixed_div:这下它可以利用绝对值进行定位了,因为在这个场景下,这个页面100%地被那个假冒的body给独霸了,而滚动条反正也出不来,您就可以自认为是在某个点蹲坑了,绝对安全。
固定定位:position:fixed固定定位是相当于“当前窗口”来进行的定位。
固定定位元素不再占空间,层级要高于普通元素,跟“浮动”很像。
固定定位元素,是一个“块元素”,换句话说,行内元素使用fixed定位,将转成“块元素”。
如果只指定了fixed定位属性,并没有设置偏移量,则“原地不动”。
绝对定位absolute
绝对定位元素,相对于“祖先定位元素”进行的定位。
如果父元素没有定位属性的话,则再往上找父定位元素,如果一直找到<body>元素,都没有找定位元素的话,则最终就相对于body来定位。
如果父元素是定位元素(相对或绝对)的话,那么绝对定位元素,就相对于该父元素进行定位。
绝对定位元素,不再占空间,层级要高于普通元素。
绝对定位元素,是一个“块元素”。
如果只指定absolute定位,并没有设置偏移量,则元素的位置不会改变(原地不动)。