固定宽度、流式、弹性布局

假设浏览器窗口设置为1250px;
wrapper的宽度为960px;
content的宽度为920px:确保了wrapper居中时两边有20px的间距;
  secondary的宽度为230px;
  primary的宽度为670px;
    其中primary中的secondary的宽度为400px;
    primary的宽度为230px;
      padding-right为20px。

固定宽度布局

宽度以像素为单位,这种布局类型成为固定宽度的布局,非常常见的一种。

  • 优点:开发者对布局和定位有更大的控制能力,知道每个元素的精确宽度,就能够对它们进行精确的布局,而且知道所有东西在什么地方。
  • 缺点:①宽度是固定的,无论窗口尺寸多大它们的尺寸都不变,所以空间利用率不高,不适应灵活的web。②行长和文本易读性:固定宽度布局往往适合于浏览器默认文本字号,但只要将文本字号增加几级,边栏就会挤满空间并且行长太短,阅读起来不舒服。
    为解决上述缺点,可使用流式布局或弹性布局代替固定宽度的布局

流式布局

流式布局中尺寸用百分比而不是像素设置。

  • 优点:使得能够相对于浏览器窗口进行伸缩,可以更好的利用空间。
  • 缺点:①窗口宽度较小时行变得非常窄,很难阅读,所以有必要加上像素或em为单位的min-width,防止布局变得太窄,但min-width设置的太大也会遇到与固定宽度相同的问题。②如果设计横跨整个浏览器窗口,那么行就会变得太长,也很难阅读。解决方法:Ⅰ、让容器之跨越宽度的一部分,Ⅱ、用百分数设置内边距和外边距,Ⅲ、对于非常严重的问题,可以为容器设置最大宽度max-width,防止内容在大显示器上变得过宽。
    将固定宽度布局的三列转换为流式三列布局:
<div class="wrapper">
    <div class="content">
        <div class="primary">
            <div class="primary">     </div>
            <div class="secondary">   </div>
        </div>
        <div class="secondary"> </div>
    </div>
</div>
<style>
        .wrapper{
            width:76.8%;   /*960÷1250=76.8%*/
            margin:0 auto;
            text-align:left;
            min-width : 62em; /*比较小的窗口尺寸,布局太挤,所以添加以em为单位的min-width*/
            max-width : 125em; /*设置为em为单位的max-width是为了确保文本行的长度适合阅读*/
        }
        .content{
            overflow: hidden;  /*加上此句后conten和wrapper容器的高度不再是0,而是100*/
        }
        .content .primary{
            width : 72.82%;  /*670÷920=72.82% ,因为在wrapper设置了水平居中,所以40px均匀分布在content容器两侧各20px*/
            float:right;
            display:inline;
        }
        .content .secondary{
            background-color: red;
            width:25%;   /*230÷920=25%*/
            float:left;
            display:inline;
        }
        .content .primary .primary{
            background-color: yellow;
            width:59.7%;  /*400÷670=59.7%*/
            float:left;
            display:inline;
        }
        .content .primary .secondary{
            background-color: blue;
            width:34.33%;   /*230÷670=34.33%*/
            padding-right:3%;   /*20÷670=3% 设置内边距,避免其包含的文本紧挨着元素的右边缘*/
            float:right;
            display:inline;
        }
</style>

流式布局的缺点:在大分辨率显示屏上,行仍然会过长,让用户不舒服,在窄窗口或在增加文本字号时,行会变得非常短,内容很零碎。
解决方法:弹性布局

弹性布局

相对于字号(而不是浏览器宽度)来设置元素的宽度,单位为em,可以确保在字号增加的时候整个布局随之扩大。
缺点:①不能充分的利用空间②因为在字号增加的时候整个布局随之扩大,所以弹性布局会变得比浏览器窗口宽,导致水平滚动条的出现,解决方法是在容器div上添加100%的max-width。
将固定宽度布局的三列转换为弹性三列布局:技巧:设置基字号,让1em大致相当于10px,浏览器默认字号是16px,10px是16px的62.5%,所以在主题上将字号设置为62.5%即可。
内部宽度仍使用百分数,只以em为单位设置容器的宽度,这样的话,内部宽度仍是相对于字号的,可以更方便的修改布局的总尺寸,不必修改每个元素的宽度,更灵活、更易操作。

<div class="wrapper">
    <div class="content">
        <div class="primary">
            <div class="primary">     </div>
            <div class="secondary">   </div>
        </div>
        <div class="secondary"> </div>
    </div>
</div>
<style>
        body{
            font-size:62.5%;
            text-align:center;
        }
        .wrapper{
            width:92em;   /*容器宽度以em为单位*/
            margin:0 auto;
            text-align:left;
            max-width : 95%;
        }
        .content{
            overflow: hidden;  /*加上此句后conten和wrapper容器的高度不再是0,而是100*/
        }
        .content .primary{
            width : 72.82%;  /*670÷920=72.82%  内部宽度仍使用百分数*/
            float:right;
            display:inline;
        }
        .content .secondary{
            background-color: red;
            width:25%;   /*230÷920=25%   内部宽度仍使用百分数*/
            float:left;
            display:inline;
        }
        .content .primary .primary{
            background-color: yellow;
            width:59.7%;  /*400÷670=59.7% 内部宽度仍使用百分数*/
            float:left;
            display:inline;
        }
        .content .primary .secondary{
            background-color: blue;
            width:34.33%;   /*230÷670=34.33%  内部宽度仍使用百分数*/
            padding-right:2em;   /*2em=20px 设置内边距,避免其包含的文本紧挨着元素的右边缘*/
            float:right;
            display:inline;
        }
</style>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,122评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,070评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,491评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,636评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,676评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,541评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,292评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,211评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,655评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,846评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,965评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,684评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,295评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,894评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,012评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,126评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,914评论 2 355

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,753评论 1 92
  • 一、静态布局(Static Layout)即传统Web设计,网页上的所有元素的尺寸一律使用px作为单位。1、布局特...
    HowlEagle101Div阅读 6,354评论 0 18
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,657评论 18 139
  • 一:在制作一个Web应用或Web站点的过程中,你是如何考虑他的UI、安全性、高性能、SEO、可维护性以及技术因素的...
    Arno_z阅读 1,160评论 0 1
  • y先生通过几天的工作发现自己是一个工作狂 在未来无法给予Q小姐想要的温暖和关怀 y先生开始慌了 Q小姐发现y先生...
    塔塔猫阅读 206评论 0 0