一、DIV布局按照定位的方法分为:浮动方法(float),坐标定位方法(position),还有就是两者相结合的方法。

二、DIV布局按照定义单位的不同可分为:固定宽度布局、流体布局、弹性布局和混合布局。

 固定宽度布局是将宽度用像素单位定义,它的宽度总保持不变,也被成为“冰布局”。

  它的缺点是由于宽度固定,无论浏览器窗口尺寸有多大,它的尺寸也不变,无法充分利用空间。

  当浏览器窗口变小时,会出现水平滚动条。这些缺点可以用其他两种布局方法解决。

  流体布局的单位是用百分比控制的,不是像素。这使流体布局能够相对于浏览器的窗口进行伸缩。

  当窗口变大,列变宽,相反,窗口变小,列的宽度也减小,这种布局方法可以有效的利用空间。

  当然,它也不是没有缺点,当窗口变小时,流体布局中的字体就会挤到一起,很难看清。这种问题可以用弹性布局方法解决。

弹性布局是用相对于字号来设置元素宽度的,而不是浏览器的宽度,通过用em为单位设置宽度,可以让字号增加时整个布局随之扩大。

  但它的缺点和固定宽度布局相同,不能很好的利用可用空间,而且在字体过大时,列宽度也会随之变大,导致浏览器中出现滚动条。

混合布局顾名思意就是将集中布局方法组合起来使用,取各自之所长,这方面的例子我还没有做过,大家可以经过学习自己摸索,万变不离其踪,方法只有这几种,全看自己怎么应用了。

  布局方法有的宽度单位运用的是像素,有的是百分比,这两种都有各自的优缺点,百分比的布局更适应浏览器窗口大小变化时产生的差异,可以充分利用空间,但当浏览器窗

口过小时,内容会变得太窄。

  另外一种布局方法可以解决这个问题,它就是弹性布局。弹性布局是用相对于字号来设置元素单位的,而不是浏览器的宽度。

  通过以em为单位设置宽度,可以确保在字号增加时整个布局随之扩大。

现在我们做个两栏布局例子,将所有像素宽度转换为使用em为单位的弹性布局。

主要技巧就是设置基础字号,让1em大致相当于12像素(一般做页面时用到的字号),这时需要利用到浏览器默认字体的相关知识。大多数浏览器的默认字号是16像素,12像素大约是16像素的75%,所以将页面上的字号设置为75%

    body {
font-size:%
}

 

下面将CSS中的固定宽度转换为弹性布局:

body {font-size:%;margin:0px;background:#FFF;color:#;} /*页面层容器*/
#wrap {width:75em;clear:both;} /*页面头部*/
#Header {clear:both;height:.3em;background:#FFCC99;} /*页面主体*/
#PageBody {clear:both;height:.3em;background:#CCFF00;}
#Sidebar {width:.7em;float:left;}
#MainBody {width:.3em;float:right;height:%;background:#EEE;} /*页面底部*/
#Footer {clear:both;height:.2em;background:#00FFFF;}

Html不做修改,还保持以下结构:

<div id="wrap"><!--页面层容器-->
<div id="Header">页面头部</div>
<div id="ageBody"><!--页面主体-->
<div id="Sidebar">侧边栏</div>
<div id="MainBody">主体内容</div>
</div>
<div id="Footer">页面底部</div>
</div>

在常规文本字号时,页面中的布局和原来基本相似,但当页面中的字体变大时,布局就会随之变大了,缩小时亦然。

使用em为单位制作两列弹性布局的更多相关文章

  1. css 两列自适应布局的4种思路

    前面的话 前面已经介绍过css 两列布局中单列定宽单列自适应布局的6种思路的两列布局,而两列自适应布局是指一列由内容撑开,另一列撑满剩余宽度的布局方式.本文将从float.table.flex和gri ...

  2. css两列自适应布局的多种实现方式及原理。

    两列布局是非常常见的需求在实际项目中,实现的方式也有很多.究其原理也都不算复杂.这里主要提出几种实现方式和原理. html页面基本布局如下代码所示: 1 <div class="mai ...

  3. ch8 基于浮动的布局(两列浮动布局、三列浮动布局)

    CSS布局技术的根本是3个基本概念:定位.浮动.外边距操纵. 只需要设置希望定位的元素的宽度,然后将它们向左或向右浮动.因为浮动的元素不再占据文档流中的任何空间,它们就不再对包围他们的块框产生任何影响 ...

  4. 使用display:table实现两列自适应布局

    在张鑫旭大神那边看到的方法,我自己写了一遍,稍微添加了一些自己的风格特色. IE6/7不支持这个属性,从IE8开始支持这个属性,对于IE6/7可以用display:inline-block解决. ta ...

  5. CSS3中的弹性布局——"em"的用法

    使用CSS也好久了,但一直都是在使用“px”来设置Web元素的相关属性,未敢使用“em”.主要原因是,对其并不什么了解,只知道一点概念性的东西,前段时间在项目中要求使用“em”作为单位设置元素,所以从 ...

  6. CSS中的EM属性之弹性布局

    这篇教程将引导大家如何使用“em”来创建一个基本的弹性布局,从而学习其如何计算?又是如何使用“em”对层进行弹性扩展?又是如何扩展文本和图像等内容?下在我们就一起带着这些问题开始今天的“em”之行. ...

  7. 慕课笔记利用css进行布局【两列布局】

    <html> <head> <title>两列布局</title> <style type="text/css"> bo ...

  8. CSS读书笔记(1)---选择器和两列布局

    (1)CSS选择器优先权选择. 优先权从大到小的选择如下: 标有!important关键字声明的属性 HTML中的CSS样式属性 <div style="color:red" ...

  9. ch8 固定宽度、流式、弹性布局

    假设浏览器窗口设置为1250px:wrapper的宽度为960px:content的宽度为920px:确保了wrapper居中时两边有20px的间距:  secondary的宽度为230px:  pr ...

随机推荐

  1. play framework 从环境搭建到简单运行

    download 官网:https://www.playframework.com/ 将zip下载至本地,进行unzip. 环境变量 检测是否安装成功:解压成功后进入解压的目录,运行 play 终端显 ...

  2. python元祖,join(),range()

    一.元祖定义 元组:俗称不可变的列表,又被成为只读列表,元祖也是python的基本数据类型之一,用小括号括起来,里面可以放任何数据类型的数据,查询可以,循环也可以,切片也可以.但就是不能改. 儿子不能 ...

  3. <scrapy爬虫>爬取quotes.toscrape.com

    1.创建scrapy项目 dos窗口输入: scrapy startproject quote cd quote 2.编写item.py文件(相当于编写模板,需要爬取的数据在这里定义) import ...

  4. 【bzoj 2870】 最长道路tree

    题目 边分治 边分和点分相比就是找到一条重心边,考虑所有经过这条边的路径,之后断开这条边分成两个联通块,继续分治 由于每次分治重心是一条边,所以只会产生两个联通块,考虑两个联通块显然要比像点分那样考虑 ...

  5. Ring HDU - 2296 AC自动机+简单DP和恶心的方案输出

    题意: 就是现在给出m个串,每个串都有一个权值,现在你要找到一个长度不超过n的字符串, 其中之前的m个串每出现一次就算一次那个字符串的权值, 求能找到的最大权值的字符串,如果存在多个解,输出最短的字典 ...

  6. centos 7 开机启动服务项优化

    1. 使用 systemctl list-unit-files 可以查看启动项 systemctl list-unit-files | grep enable 过滤查看启动项如下 abrt-ccpp. ...

  7. [洛谷P3672]小清新签到题

    题目描述 题目还是简单一点好. 给定自然数n.k.x,你要求出第k小的长度为n的逆序对对数为x的1~n的排列a1,a2...an,然后用仙人图上在线分支定界启发式带花树上下界最小费用流解决问题,保证存 ...

  8. Entity Framework Code First 模式-建立一对一联系

    使用的例子为教室(ClassRoom),教室里的多媒体设备(Device),一个教室里有一套多媒体设备,一套多媒体设备只放在一个教室里. 1.Data Annotations方式 需要在任意一方的主键 ...

  9. 【JZOJ3337】wyl8899的TLE

    description wyl8899今天也很刻苦的在做老师布置下来的题目! 这一天老师布置的题目是这样的: 给出两个仅含小写字母的字符串A和B,输出最大的k,使得A[1..k]是B的子串. A和B的 ...

  10. 洛谷P2526 【SHOI2001】小狗散步

    原题传送门 题目背景 Grant喜欢带着他的小狗Pandog散步.Grant以一定的速度沿着固定路线走,该路线可能自交.Pandog喜欢游览沿途的景点,不过会在给定的N个点和主人相遇.小狗和主人同时从 ...