1 左右自适应布局
#left {
background-color: #FFFF33;
height:250px;
width:25%;
border:10px solid #000000;
float:left;
margin:10px;
}
#right
{
height:250px;
width:60%;
border:10px solid #000000;
background-color: #FFFF33;
float:right;
margin:10px;
}
2 float属性用来设置流布局,也就是象水一样自动流动。如果是左边的话 left就会自动和最左边的
一个对象的旁边靠齐
3 position用来设置位置的,有相对relative和 绝对absolute
4 margin是用来设置对象和外面的对象之间的距离的 也就是对象的边外延
.cent{
margin-top:100px;
margin-right:auto;
margin-bottom:0px;
margin-left:auto;
}
左右设置为auto则为居中 浏览器在判断的时候会将左右边界设置为相同距离所以会居中
顺序是上右下左
4 CSS的盒模型,对象的真实宽度是由对象的宽度+左右填充+左右边框+左右边界构成。
css注释只能用/**/
6 2列自适应布局
.left
{
float:left;
height:250px;
width:30%;
background-color:#000000;
border:1px solid:#FFFF33;
position:relative;
}
.right
{
height:250px;
background-color:#CCCC00;
margin-left:32%;
}
多应用与blog系统中,这个好 正好拿来用用
7 2列左边固定 右边宽度自适应
在right中不设置任何右边宽度的值
.left
{
float:left;
height:250px;
width:120px;
background-color:#000000;
border:5px solid:#FFFF33;
margin:10px;
}
.right
{
border:5px solid:#000000;
background-color:#FF0000;
margin:10px;
height:250px;
}
8 2列固定宽度居中
需要一个嵌套的div
<div id="cent" class="cent">
<div id="left" class="left">此处显示新 left 标签的内容</div>
<div id="right" class="right">此处显示新 Div 标签的内容</div>
</div>
.cent
{ margin-top:0px;
margin-right:auto;
margin-bottom:0px;
margin-left:auto;
width:490px;
}
.left
{
float:left;
height:250px;
width:100px;
background-color:#000000;
border:10px solid:#FF0000;
}
.right
{
float:left;
height:250px;
width:350px;
background-color:#FF0000;
border:10px solid:#000000;
}
9 3列固定宽度布局内容自动调整
缺陷: 浏览器缩的太小的话就难看了
.left
{
float:left;
height:250px;
width:200px;
background-color:#000000;
border:10px solid:#FF0000;
}
.cent
{
border:10px solid:#FFFF33;
height:250px;
width:480px;
background-color:#FF0000;
float:left;
}
.right
{
float:left;
height:250px;
width:200px;
background-color:#FF0000;
border:10px solid:#000000;
}
10 3列固定列宽度布局 内容也固定了
浏览器怎么变内容都不会变
.left
{
float:left;
height:250px;
width:200px;
background-color:#000000;
border:10px solid:#FF0000;
position:absolute;
left:0px;
top:0px;
}
.cent
{
border:10px solid:#FFFF33;
height:250px;
width:440px;
background-color:#FF0000;
position:absolute;
margin-right:220px;
margin-left:220px;
margin-top:0px;
}
.right
{
float:left;
height:250px;
width:200px;
background-color:#FF0000;
border:10px solid:#000000;
position:absolute;
left:680px;
top:0px;
}
body
{
margin:0px 0px 0px 0px;边界
padding:0px 0px 0px 0px;填充就是距离内部的多远 把哪个部分填充掉
}
11 顶行三列式布局
.left
{
float:left;
height:250px;
width:200px;
background-color:#000000;
border:10px solid:#FF0000;
position:absolute;
left:0px;
top:120px;
}
.cent
{
border:10px solid:#FFFF33;
height:250px;
width:440px;
background-color:#FF0000;
position:absolute;
margin-right:220px;
margin-left:220px;
margin-top:10px;
}
.right
{
float:left;
height:250px;
width:200px;
background-color:#FF0000;
border:10px solid:#000000;
position:absolute;
left:680px;
top:120px;
}
.top
{
background-color:#0033CC;
border:10px solid:#000000;
height:100px;
margin-top:0px;
margin-right:0px;
margin-left:0px;
}
12 一个对象的高度是否使用白分比显示,取决于对象的父级对象。
例如<body>
<div class="div1">此处显示新 Div 标签的内容</div>
</body>
.div1 {
height:100%;
background-color:#FF0000;
}
高度就不能显示出100%
只有用了这个样式表后
body
{
margin:0px 0px 0px 0px;
height:100%;
}才能显示出100%
13 在使用div嵌套的时候,如果外层对象的尺寸大小不允许被改变,就是说宽和高是固定的 这个时候使用填充的话如果左和上都填充20px就相当于把外层对象的宽和高都增加了20px,这时候里面对象就可能不处在中间位置了,改变的办法是把外层对象高和宽都减少20px;还有一种办法是设置内层对象的边界值,不设置外层对象的填充值
14 css导行栏动态菜单
<div id="globalLink"> <a href="#" id="gl1" class="glink" onmouseover="ehandler
(event,menuitem1);">global link</a></div>
<div id="subglobal1" class="subglobalNav"> <a href="#">subglobal1 link</a> | <a
href="#">subglobal1 link</a> | <a href="#">subglobal1 link</a> | <a href="#">subglobal1 link</a>
| <a href="#">subglobal1 link</a> | <a href="#">subglobal1 link</a> | <a href="#">subglobal1
link</a> </div>
css如下
.subglobalNav{
position: absolute;
top: 84px;
left: 0px;
/*width: 100%;*/
min-width: 640px;
height: 20px;
padding: 0px 0px 0px 10px;
visibility: hidden;
color: #ffffff;
}
a.glink, a.glink:visited{
font-size: small;
color: #000000;
font-weight: bold;
margin: 0px;
padding: 2px 5px 4px 5px;
border-right: 1px solid #8FB8BC;
}
javascript如下
<script type="text/javascript">
<!--
var menuitem1 = new menu(7,1,"hidden");
var menuitem2 = new menu(7,2,"hidden");
var menuitem3 = new menu(7,3,"hidden");
var menuitem4 = new menu(7,4,"hidden");
var menuitem5 = new menu(7,5,"hidden");
var menuitem6 = new menu(7,6,"hidden");
var menuitem7 = new menu(7,7,"hidden");
// -->
</script>
<script type="text/javascript">
<!--
var time = 3000;
var numofitems = 7;
function menu(allitems,thisitem,startstate){
callname= "gl"+thisitem;
divname="subglobal"+thisitem;
this.numberofmenuitems = allitems;
this.caller = document.getElementById(callname);
this.thediv = document.getElementById(divname);
this.thediv.style.visibility = startstate;
}
function ehandler(event,theobj){
for (var i=1; i<= theobj.numberofmenuitems; i++){
var shutdiv =eval( "menuitem"+i+".thediv");
shutdiv.style.visibility="hidden";
}
theobj.thediv.style.visibility="visible";
}
function closesubnav(event)
{
if ((event.clientY <48)||(event.clientY > 107)){
clientY 事件属性返回当事件被触发时鼠标指针向对于浏览器页面(客户区)的垂直坐标。用的时候需要修改
这个数值
for (var i=1; i<= numofitems; i++){
var shutdiv =eval('menuitem'+i+'.thediv');
shutdiv.style.visibility='hidden';
}
}
}
// -->
应用的时候注意在body里面添加方法closesubnav