您现在的位置是:网站首页> 编程资料编程资料
CSS实现页面两列布局与三列布局的方法示例_CSS布局实例_CSS_网页制作_
2021-08-29
2087人已围观
简介 这篇文章主要介绍了CSS实现页面两列布局与三列布局的方法示例,包括宽度与高度的自适应的示例,需要的朋友可以参考下
1. 使用BFC的原理实现
BFC的规则之一,就是BFC区域,不会与float box重叠,因此我们可以利用这一点来实现3列布局。
html代码如下
css代码如下
2.双飞翼布局
这种布局方案最早由淘宝提出,主要为了主列能够被最先加载。
实现原理:
(1)让主列外面添加一个wrap,主列wrap,以及2子列都左浮动。
(2)设置主列wrap宽度为100%,将子列的margin-left设置为负值,让子列能够排列在左右两侧。
(3)这是主列的margin-left与margin-right比左右两列的宽度大一点,则可以设置出来主列与子列之间的间隙。
html代码如下
css代码如下
3.圣杯布局
圣杯布局在结构上要简单一点,也能够让主列优先加载。
实现原理:
(1)添加一个包裹框,设置padding-leftpadding-right值,比子列宽度大一个空隙的宽度。
(2)主列,子列都设置为float: left 左子列margin-left设置为-100%,并且设置为position:relative; left: -110px将左子列放置到左侧。右子列同理。
(3)主列只需设置宽度为100%即可。包裹框的宽度不要设置为100%,自适应即可。
html代码如下
css代码如下
下面再给出一个高度占满全屏的例子:
BFC的规则之一,就是BFC区域,不会与float box重叠,因此我们可以利用这一点来实现3列布局。
html代码如下
XML/HTML Code复制内容到剪贴板
- <div class="left">div>
- <div class="right">div>
- <div class="main">div>
CSS Code复制内容到剪贴板
- .left {
- float: left;
- margin-right: 10px;
- width: 100px;
- height: 100px;
- background-color: orange;
- }
- .rightright {
- float: rightright;
- margin-left: 10px;
- width: 100px;
- height: 100px;
- background-color: orange;
- }
- .main {
- height: 100px;
- background-color: green;
- overflow: hidden;
- }
这种布局方案最早由淘宝提出,主要为了主列能够被最先加载。
实现原理:
(1)让主列外面添加一个wrap,主列wrap,以及2子列都左浮动。
(2)设置主列wrap宽度为100%,将子列的margin-left设置为负值,让子列能够排列在左右两侧。
(3)这是主列的margin-left与margin-right比左右两列的宽度大一点,则可以设置出来主列与子列之间的间隙。
html代码如下
XML/HTML Code复制内容到剪贴板
- <div class="wrap">
- <div class="main-content">
- <div class="main">div>
- div>
- <div class="left">div>
- <div class="right">div>
- div>
CSS Code复制内容到剪贴板
- .wrap {
- width: 100%;
- }
- .wrap::after {
- display: block;
- content: '';
- font-size: 0;
- height: 0;
- clear: both;
- zoom: 1;
- }
- .main-content {
- float: left;
- width: 100%;
- }
- .main {
- height: 100px;
- background-color: green;
- margin-left: 110px;
- margin-right: 110px;
- }
- .left {
- float: left;
- width: 100px;
- height: 100px;
- background-color: orange;
- margin-left: -100%;
- }
- .rightright {
- float: left;
- width: 100px;
- height: 100px;
- background-color: orange;
- margin-left: -100px;
- }
圣杯布局在结构上要简单一点,也能够让主列优先加载。
实现原理:
(1)添加一个包裹框,设置padding-leftpadding-right值,比子列宽度大一个空隙的宽度。
(2)主列,子列都设置为float: left 左子列margin-left设置为-100%,并且设置为position:relative; left: -110px将左子列放置到左侧。右子列同理。
(3)主列只需设置宽度为100%即可。包裹框的宽度不要设置为100%,自适应即可。
html代码如下
XML/HTML Code复制内容到剪贴板
- <div class="wrapper">
- <div class="main">div>
- <div class="left">div>
- <div class="right">div>
- div>
CSS Code复制内容到剪贴板
- .wrapper {
- padding-left: 110px;
- padding-right: 110px;
- overflow: hidden;
- }
- .main {
- float: left;
- width: 100%;
- height: 100px;
- background-color: #ccc;
- }
- .left {
- float: left;
- width: 100px;
- height: 100px;
- margin-left: -100%;
- position: relative;
- left: -110px;
- _left: 0;
- background-color: orange;
- }
- .rightright {
- float: left;
- width: 100px;
- height: 100px;
- background-color: orange;
- margin-left: -100px;
- position: relative;
- rightright: -110px;
- }
CSS Code复制内容到剪贴板
- "_blank" href="http://www.w3.org/1999/xhtml">http://www.w3.org/1999/xhtml">
- "server">
- "Content-Type" content="text/html; charset=utf-8" />
-
- "header">
- 上
"h_menu">- 上_底
"middle">"left">- 中左
"right">- 中右
"center">- 中间
"footer">- 下
相关内容
- CSS3+DIV实现漂亮的动画彩色标签_css3_CSS_网页制作_
- CSS3美化表单控件全集_css3_CSS_网页制作_
- CSS3字体效果的设置方法小结_css3_CSS_网页制作_
- Content-type的说明即HTTP请求头的类型整理_HTML/Xhtml_网页制作_
- input元素[type="file"]时的样式定制及浏览器兼容性问题探讨_HTML/Xhtml_网页制作_
- checkbox的indeterminate属性使用介绍_HTML/Xhtml_网页制作_
- 如何点击a标签实现弹出input file上传文件对话框_HTML/Xhtml_网页制作_
- html中select optgroup标签使用介绍_HTML/Xhtml_网页制作_
- HTML教程:收集的常用的HTML标签(6)_HTML/Xhtml_网页制作_
- HTML表格标记教程(40):表头的暗边框色属性BORDERCOLORDARK_HTML/Xhtml_网页制作_
