1. 一个浮动(左浮动或右浮动)
  2. 垂直环绕布局(float、clear
  3. 左右两列布局(float、absolute)
  4. 三栏网页宽度自适应布局(float、absolute)

注意:网页设计中应该尽量避免使用浮动。避免使用absolute

1、一个浮动(左浮动或右浮动)

当一个div里面含有浮动元素和非浮动元素,IE6,7中的浮动元素会出现错位现象。
解决方案:  ①将浮动元素位于非浮动元素的前面。②非浮动设置为浮动元素。③浮动元素设置margin-top的负值。
<div class="title"><span>新闻列表</span><a href="javascript:;" class="r">更多</a> </div>
(在firefox、chrome、ie8+浏览器表现正常)
 
2、垂直环绕布局(float、clear)
.touxiang{ width:100px; height:100px; background-color: #dcdcdc; display: inline-block;}
<div class="fix">
<span class="touxiang l">头像</span> /*(左浮动)*/
<span class="l cll">姓名</span>        /*(左浮动,清除左浮动)*/
<div class="bde" style="margin-left: 120px;">自我描述</div> /*(没有浮动)*/
</div>
运行效果:
 
3、左右两列布局(float、absolute)
①当不要用到左栏收缩的时候同1、浮动div写在非浮动前面
用float布局:
/*.container { overflow:hidden; }*/ 用fix清除浮动
.aside{ float:left; width:300px; }
.right{ margin-left:310px; }
 
②需要用到左栏收缩(以高度不固定为例)
用absolute布局:  不推荐!!!!!!!!!!
 .header{ height: 70px;}
.aside{
width:300px; border-right: 1px solid #dedede;
position: absolute; top: 0; left: 0; z-index: 999;
}
.right{ margin-left: 310px; /*注意:ie6出现错位现象,需添加 display: inline;或者改为padding-left。或者其它。。。 详见《css浏览器兼容集锦》*/}
.toggle {
width: 18px; height: 63px; line-height: 58px;
vertical-align: middle;
position: absolute; left: 300px; top: 60px; z-index: 1001;
border-width: 1px; border-style: solid; border-color: #bbb #bbb #bbb #fff;
border-top-right-radius: 3px; border-bottom-right-radius: 3px;
}
/*三角形 注意另外两种方式实现,有什么区别。详细见《css三角形实现的几种方法的区别》*/
.toggle em {
height: 0;width: 0; display: inline-block; margin-left: 5px; overflow: hidden;
border-style: dashed solid; border-width: 5px 5px 5px 0px;
border-color: transparent #D0D4DA transparent transparent;
}
.toggle:hover em { border-color: transparent #52bf88 transparent transparent; }
.shrink em {
border-style: dashed solid; border-width: 5px 0px 5px 5px;
border-color: transparent transparent transparent #D0D4DA;
}
.shrink:hover em { border-color: transparent transparent transparent #52bf88; }
<div class="fz">
<div class="header bg-red">头部</div>
<div id="container" class="mt10 rel">
<a id="toggle" class="toggle" href="javascript:;">
<em></em>
</a>
<div id="aside" class="aside l">
<div style="height: 800px;">left</div>
</div>
<div id="right" class="right">right</div>
</div>
</div>
js代码:
<script>
var $aside = $("#aside");
var $right=$("#right");
var $toggle = $("#toggle");
$(function(){
leftToggle();
})
function leftToggle(){
var flip = 0;
$("#toggle").click(function () {
if (flip % 2 == 0) {
contraction();
}
else {
expansion();
}
flip += 1;
})
}
//收缩
function contraction(){
$aside.animate({ left: "-300px"}, 300, function () {
$toggle.addClass("shrink");
});
$toggle.animate({left:"1px"},300,function(){
$right.css("margin-left","1px");
}); /*可优化,看怎样用一个animate实现*/
}
//展开
function expansion(){
$aside.animate({ left: "0" }, 300, function () {
$toggle.removeClass("shrink");
});
$toggle.animate({left:"300px"},300,function(){
$right.css("margin-left","310px");
}); /*同上*/
}
</script>
效果:(点击可伸缩)
 
4、三栏网页宽度自适应布局(float、absolute)
①绝对定位  不推荐!!!!!!!!!!!!
.left, .right { position: absolute; top: 0; width: 200px; height: 100%; background-color: #ff4136; }
.left { left: 0; }
.right { right: 0; }
.main { margin: 0 210px; background: yellowgreen; height: 100%;}
<div class="fz">
<div class="left">left</div>
<div class="main">main</div>
<div class="right">right</div>
</div>

运行效果:

问题:不能设置“main”的最小宽度,当设置.main{min-width: 500px;} 缩小浏览器到最小宽度,main跟right区域重合。

②margin负值法

.main{ width: 100%; float: left;}
.main .body{ margin: 0 210px; background-color: yellowgreen;}
.left,.right{ width: 200px; float: left; background-color: #ff4136;}
.left{ margin-left: -100%;}
.right{ margin-left: -200px;}
<div class="fz fix">
<div class="main">
<div class="body">body</div>
</div>
<div class="left">left</div>
<div class="right">right</div>
</div>

当main里面的body设置最小宽度同样出现“body“部分跟”right“部分重叠

③自身浮动法

.main { height: 100%; margin: 0 210px; background-color: yellowgreen; }
.left, .right { width: 200px; height: 100%; background-color: #ff4136; }
.left { float: left; }
.right { float: right; }
<div class="fz fix">
<div class="left">left</div>
<div class="right">right</div>
<div class="main">main</div>
</div>

注意:div的顺序以及main部分不能用clear:both属性。设置main最小宽度同样不行

网页布局的应用(float或absolute)的更多相关文章

  1. 常见div+css网页布局(float,absolute)

    网页布局-常见 1,           float布局 (1)常规方法 <div id="warp">     <div id="column&quo ...

  2. 【CSS】 布局之浮动float和绝对定位absolute的选择

    浮动float: 浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止. 由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样.(W3C) 绝对定位 ...

  3. CSS网页布局全精通

    在本文中将使用四种常见的做法,结合CSS于结构化标记语法制作两栏布局.很快地就会发现,不用嵌套表格,间隔用的GIF也能做出分栏版面布局. 相关文章:CSS网页布局开发小技巧24则 稍后在"技 ...

  4. 《精通CSS网页布局》读书报告 ----2016-12-5补充

    第一章:CSS布局基础 1.CSS的精髓是布局,而不是样式哦!  (定要好好的研究布局哦,尤其配合html5) 2. html标签的语义性,要好好的看看哦! 3.DTD:文档类型定义. 4.内联--& ...

  5. 一、HTML和CSS基础--网页布局--网页布局基础

    W3C标准: 由万维网联盟制定的一系列标准,包括: 结构化标准语言(HTML和XML) 表现标准语言(CSS) 行为标准语言(DOM和ECMAScript) 倡导结构.样式.行为分离. CSS 规定的 ...

  6. PHP.4-DIV+CSS标准网页布局准备工作(下)

    DIV+CSS标准网页布局准备工作 区块属性(区块模型) 属 性 描 述 Margin(注) 是定义区块外边界与上级元素距离的属性,用1到4个值来设置元素的边界,每个值都是长度.百分比或者auto,百 ...

  7. PHP.3-DIV+CSS标准网页布局准备工作(上)

    DIV+CSS标准网页布局准备工作(上) 概述 使用"DIV+CSS"对网站进行布局符合W3C标准,采用这种方式布局通常是为了说明与HTML表格定位方式的区别.因为现在的网站设计标 ...

  8. 总结与学习DIV+CSS网页布局技巧

    以前用表格布局时设置网页居中非常方便,把表格对齐方式设置为居中就行了,就这么简单,现在呢,用DIV+CSS样式表控制,好像不是那么容易了,其实也很简单,只不过方式不同而已. <style> ...

  9. DIV+CSS 网页布局之:混合布局

    1.混合布局 在了解了一列.两列和三列布局之后,混合布局也就不难理解了,混合布局也可以叫综合型布局,那么混合布局就可以在一列布局的基础之上,分为两列布局,三列布局,网页布局的结构普遍都是三列布局,但是 ...

随机推荐

  1. django admin页面样式丢失问题

    wamp 配置django admin页面样式丢失问题 第一种方法:在apache配置文件httpd.conf中加入如下代码:Alias /static "E:\Python27\Lib\s ...

  2. ylb:sql语句重命名表名和列名

    ylbtech-SQL Server:SQL Server-sql语句重命名表名和列名 sql语句重命名表名和列名 ylb:sql语句重命名表名和列名 返回顶部 一.更改数据库名    sp_rena ...

  3. ASP.NET Web API路由规则(二) 【转】

    http://www.cnblogs.com/liulun/archive/2012/06/20/2556556.html 默认的规则 在ASP.NET MVC4中 global.asax.cs代码中 ...

  4. hadoop datanode节点超时时间设置

    datanode进程死亡或者网络故障造成datanode无法与namenode通信,namenode不会立即把该节点判定为死亡,要经过一段时间,这段时间暂称作超时时长. HDFS默认的超时时长为10分 ...

  5. 社区之星礼品开箱——感谢CSDN

    前言 尽管已经看过国内外无数的开箱.评測视频,也看过无数国内社区的各种玩具.电子产品.摄影的分享贴.自己却从未写过--摄影水平有限以及懒-- 昨天看到上图的文章,看到最后都说了应该晒晒照片.写写博客, ...

  6. 【Excle数据透视表】如何快速选取所有标签并标注黄色底纹

    如下图:需要把所有标签标注为黄色底纹该如何操作呢? 步骤 单击数据透视表任意单元格→数据透视表工具→分析→选择→整个数据透视表→选择→标签→开始→字体组合中"填充颜色" 第一次选择 ...

  7. hadoop生态系统学习之路(六)hive的简单使用

    一.hive的基本概念与原理 Hive是基于Hadoop之上的数据仓库,能够存储.查询和分析存储在 Hadoop 中的大规模数据. Hive 定义了简单的类 SQL 查询语言,称为 HQL.它同意熟悉 ...

  8. 网络工具的瑞士军刀netcat

    这是一个聒噪的夜晚,假设要给出个原因.可能是由于尽管我认为西班牙不纯粹,可是怎么也不至于干为人家搭台面自己不唱戏的角色吧..结束以后.我认为该玩一下素有网络瑞士军刀之称谓的netcat了. 尽管瑞士军 ...

  9. hdu 2063过山车

    二分匹配 #include<iostream> #include<cstring> using namespace std; int k,m,n; int rem[500+5] ...

  10. 百度富文本编辑器Ueditor上传图片时标签中添加宽高

    ueditor.all.js中:直接搜索callback() function callback(){ try{ var link, json, loader, body = (iframe.cont ...