视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
调整页面布局的几种方法
2020-11-27 18:50:09 责编:小采
文档

1.使用浮动布局
优点:兼容性比较好。
缺点:浮动后,元素是脱离文档流的,需要谨慎处理好清除浮动还有浮动的元素和周边元素之间的关系

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>页面布局</title>
 <style>
 * {
 margin: 0;
 padding: 0;
 }
 .layout{
 margin: 20px;
 }
 .layout article p{
 min-height: 100px;
 }
 
 </style>
</head>
<body>
 <!-- 浮动解决方案 -->
 <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">
 <p class="left"></p>
 <p class="right"></p>
 <p class="center">
 <h1>浮动解决方案</h1>
 1.这是三栏布局中间部分
 1.这是三栏布局中间部分
 </p>
 </article>
 </section>
</body>
</html>

注意:最要注意的一点是,中间列一定要放在左右两列的后面!!!

2.使用绝对定位布局
优点:布局相对迅速
缺点:定位的元素脱离了文档流,意味着其子元素也要脱离文档流,所以这种方式的可使用性比较差

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>页面布局</title>
 <style>
 * {
 margin: 0;
 padding: 0;
 }
 .layout{
 margin: 20px;
 }
 .layout article p{
 min-height: 100px;
 }
 
 </style>
</head>
<body>
<!-- 绝对定位解决方案 -->
 <section class="layout absolute">
 <style>
 .layout.absolute .left-right-center{
 position: relative;
 }
 .layout.absolute .left{
 position: absolute;
 left: 0;
 width: 300px;
 background: red;
 }
 .layout.absolute .right{
 position: absolute;
 right: 0;
 width: 300px;
 background: blue;
 }
 .layout.absolute .center{
 position: absolute;
 left: 300px;
 right: 300px;
 background: yellow;
 }
 </style>
 <article class="left-right-center">
 <p class="left"></p>
 <p class="center">
 <h2>绝对定位解决方案</h2>
 1.这是三栏布局绝对定位解决方案
 1.这是三栏布局绝对定位解决方案
 </p>
 <p class="right"></p>
 </article>
 </section>
</body>
</html>

3.使用flex布局

优点: 很好的解决了浮动和绝对定位的缺点,现在移动端基本都是用flex布局
ie8以下 不支持flex

<section class="layout flex">
 <style>
 .layout.flex .left-right-center{
 display: flex;
 margin-top: 140px;
 }
 .layout.flex .left{
 flex: 0 0 300px;
 width: 300px;
 background: red;
 }
 .layout.flex .right{
 flex: 0 0 300px;
 width: 300px;
 background: blue;
 }
 .layout.flex .center{
 flex: 1;
 background: yellow;
 }
 </style>
 <article class="left-right-center">
 <p class="left"></p>
 <p class="center">
 <h2>Flexbox解决方案</h2>
 1.这是三栏布局flexbox解决方案
 1.这是三栏布局flexbox解决方
 </p>
 <p class="right"></p>
 </article>
 </section>

注意: 中间列要放在中间!!!

4.使用表格布局
优点:兼容性还不错
缺点:其中一栏内容高度增加,另外两栏的高度也会增加,有时我们并不需要他们同时增高;不利于搜索引擎抓取信息;

<!-- 表格布局解决方案 -->
	<section class="layout table">
	<style>
	.layout.table .left-right-center{
	width: 100%;
	display: table;
	height: 100px;
	}
	.layout.table .left{
	display: table-cell;
	width: 300px;
	background: red;
	}
	.layout.table .right{
	display: table-cell;
	width: 300px;
	background: blue;
	}
	.layout.table .center{
	display: table-cell;
	background: yellow;
	}
	</style>
	<article class="left-right-center">
	<p class="left"></p>
	<p class="center">
	<h2>表格布局解决方案</h2>
	1.这是三栏布局表格布局解决方案
	1.这是三栏布局表格布局解决方案
	</p>
	<p class="right"></p>
	</article>
	</section>

5.网格布局

<!-- 网格布局解决方案 -->
	<section class="layout grid">
	<style>
	.layout.grid .left-right-center{
	width: 100%;
	display: grid;
	grid-template-rows: 100px;
	grid-template-columns: 300px auto 300px;	
	}
	.layout.grid .left{
	background: red;
	}
	.layout.grid .right{
	background: blue;
	}
	.layout.grid .center{
	background: yellow;
	}
	</style>
	<article class="left-right-center">
	<p class="left"></p>
	<p class="center">
	<h2>网格布局解决方案</h2>
	1.这是三栏布局网格布局解决方案
	1.这是三栏布局网格布局解决方案
	</p>
	<p class="right"></p>
	</article>
	</section>

假如把高度已知去掉或者高度超出
1.flex布局高度可以自适应
2.表格布局奥杜可以自适应
3.浮动,绝对定位,网格布局不能自适应高度

下载本文
显示全文
专题