内容简介:以下整理给金三银四求职的小伙伴,同时也是为了巩固笔者所学的知识,希望对大家有所帮助,后面将会陆续整理出其他篇章 js 系列 、http 、算法等...本文探讨下面试常谈问题之三栏布局,说到三栏布局,可能大家心中至少也可以想出 2-3 种答案,这些谷歌就一大堆解决方案的题目为什么还要拿出来谈谈呢?这里主要是考察掌握知识度的延伸,比如你能答出几种? => 这几种方式的优缺点在哪? => 最佳方案是哪个以及如何解决这些缺点...
以下整理给金三银四求职的小伙伴,同时也是为了巩固笔者所学的知识,希望对大家有所帮助,后面将会陆续整理出其他篇章 js 系列 、http 、算法等...
本文探讨下面试常谈问题之三栏布局,说到三栏布局,可能大家心中至少也可以想出 2-3 种答案,这些谷歌就一大堆解决方案的题目为什么还要拿出来谈谈呢?
这里主要是考察掌握知识度的延伸,比如你能答出几种? => 这几种方式的优缺点在哪? => 最佳方案是哪个以及如何解决这些缺点...
这些可以考验到你是否背题亦或者真正掌握到这些知识点。
高度已知,实现三栏布局,左右 300px 中间自适应。
在实现前先重置一下默认的样式
* { margin: 0; padding: 0; } .layout { margin-top: 20px; } .layout article div { min-height: 100px; } 复制代码
浮动布局解决方案
左右浮动,给宽度,这样就实现了,是不是很简单~但是也存在一些缺点,后边会讲到。
<section class="layout float"> <style> .layout.float .left { float: left; width: 300px; background: red; } .layout.float .right { float: right; width: 300px; background: blue; } .layout.float .center { background: yellow; } </style> <article class="left-right-center"> <div class="left"></div> <div class="right"></div> <div class="center"> <h1>浮动解决方案</h1> 1. 这是三栏布局中间部分 2. 这是三栏布局中间部分 </div> </article> </section> 复制代码
绝对定位布局解决方案
left/center/right
均给绝对定位,左右给 300px,中间设置 left 300 right 300
,也同样实现这个布局~
<!-- 绝对定位解决方案 --> <section class="layout absoulute"> <style> .layout.absoulute .left-center-right > div { position: absolute; } .layout.absoulute .left { left: 0; width: 300px; background: red; } .layout.absoulute .center { left: 300px; right: 300px; background: yellow; } .layout.absoulute .right { right: 0; width: 300px; background: blue; } </style> <article class="left-center-right"> <div class="left"></div> <div class="center"> <h1>绝对定位解决方案</h1> 1. 这是三栏布局中间部分 2. 这是三栏布局中间部分 </div> <div class="right"></div> </article> </section> 复制代码
flex 布局解决方案
父级 box 给 display: flex , 左右宽 300, 中间 flex : 1
,flex 的灵活性也十分的好用 ~
<section class="layout flexbox"> <style> .layout.flexbox { margin-top: 140px; } .layout.flexbox .left-center-right { display: flex; } .layout.flexbox .left { width: 300px; background: red; } .layout.flexbox .center { flex: 1; background: yellow; } .layout.flexbox .right { width: 300px; background: blue; } </style> <article class="left-center-right"> <div class="left"></div> <div class="center"> <h1>flex 布局解决方案</h1> 1. 这是三栏布局中间部分 2. 这是三栏布局中间部分 </div> <div class="right"></div> </article> </section> 复制代码
table 布局解决方案
父级 display: table;
左中右 display: table-cell;
<section class="layout table"> <style> .layout.table .left-center-right { width: 100%; display: table; height: 100px; } .layout.table .left-center-right > div { display: table-cell; } .layout.table .left { width: 300px; background: red; } .layout.table .center { background: yellow; } .layout.table .right { width: 300px; background: blue; } </style> <article class="left-center-right"> <div class="left"></div> <div class="center"> <h1>表格布局解决方案</h1> 1. 这是三栏布局中间部分 2. 这是三栏布局中间部分 </div> <div class="right"></div> </article> </section> 复制代码
grid 布局解决方案
利用网格布局 ,父级 display: grid; width: 100%; grid-template-columns: 300px auto 300px;
<section class="layout grid"> <style> .layout.grid .left-center-right { display: grid; width: 100%; grid-template-rows: 100px; grid-template-columns: 300px auto 300px; } .layout.grid .left { background: red; } .layout.grid .center { background: yellow; } .layout.grid .right { background: blue; } </style> <article class="left-center-right"> <div class="left"></div> <div class="center"> <h1>grid布局解决方案</h1> 1. 这是三栏布局中间部分 2. 这是三栏布局中间部分 </div> <div class="right"></div> </article> </section> 复制代码
优缺点
上面我们给出 5 种解决方案,那么面试官怎么延伸这个问题呢? 如果把高度已知去掉,又该如何实现呢?那我们不止要考虑水平方向的,同时要考虑中间的高度问题。那我们刚写的五种方案,哪些可以适用,哪些又不能适用了呢 这五种方案的兼容性又如何,最优的解决方案又是哪个
- float
- 缺点:在于脱离文档流,意味着它下面的子元素也必须脱离文档流,还需要清除浮动带来的影响,如果处理不好会带来很多问题,这是它本身的局限性
- 优点:兼容性很好,快捷,不容易出问题
- absoulute
- flex
- 缺点:兼容到 IE 8
- 在 float 、absoulute 出现之后出现的一种布局方式,为了解决两种布局方式的不足。flex 布局方案算是比较完美的一种,尤其是现在移动端基本都是使用 flex 布局
- table
- 缺点:操作麻烦,对 seo 不友好 ,当某一个单元格高度超出的时候,那么其他单元格也会跟着调整高度,有时候我们场景是不允许的
- 优点:兼容性很好,当 flex 解决不了的话,可以尝试下用表格布局
- grid
- 新出的网格布局,通过 网格布局可以做很多事情,代码精简
当我们增加内容高度时会发生什么事情呢?
很明显
- 浮动布局文字自动排版到左边了。(浮动的基本原理)
- 绝对定位撑开中间部分的布局,两边不变
- flex 、table 布局中内容撑开盒子的高度 - better
- grid 布局中内容中不撑开高度
关于浮动的问题有可以延伸出来,怎么解决内容向左排版的 bug 呢?创建 BFC ,那么 BFC 又是什么呢,具体我会在下一篇文章介绍。
页面布局的变通
- 三栏布局
- 左右宽固定,中间自适应
- 上下高固定,中间自适应
- 两栏布局
- 左宽度固定,右自适应 或者相反
- 上宽度固定,下自适应 或者相反
以上所述就是小编给大家介绍的《面试之CSS篇 - 实现三栏布局的延伸》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 前端面试之居中布局
- 「前端面试题系列2」如何实现一个圣杯布局?
- css经典布局系列三——三列布局(圣杯布局、双飞翼布局)
- 四种方法实现──三栏布局(圣杯布局、双飞翼布局)
- 浅谈CSS三栏布局(包括双飞翼布局和圣杯布局)
- css经典布局——圣杯布局
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
百度SEM竞价推广
马明泽 / 电子工业出版社 / 2017-5 / 59
竞价推广已成为企业昀主要的网络营销方式,《百度SEM竞价推广:策略、方法、技巧与实战》以百度竞价推广为基础,全面阐述了整个竞价推广过程中的重要环节,涉及大量账户操作实战技巧,以及解决各类难点的方法,其中包括搜索引擎营销基础、百度搜索推广介绍、账户结构搭建技巧、关键词与创意的使用技巧、质量度优化与提升、账户工具的使用、百度推广客户端的使用、企业搜索推广方案制作、百度网盟推广、着陆页分析、效果优化与数......一起来看看 《百度SEM竞价推广》 这本书的介绍吧!