CSS布局终极方案之改进圣杯布局(兼容IE6+,现代浏览器)_html/css_WEB-ITnose

php中文网
发布: 2016-06-21 09:18:24
原创
1461人浏览过

CSS兼容所有浏览器(IE6+,现代浏览器)的终极布局方案之 -- 改进版圣杯布局

改进思想:

通过对主内容区main增加一个额外包裹层div,将原来在父节点上的 padding-left|right 设置转移到包裹层上使用 margin-left|right 替代,达到更加灵活的布局设置。

原始圣杯布局实现:

同样的效果:

立即学习前端免费学习笔记(深入)”;

CSS 和 DOM 代码如下:

<!DOCTYPE html><html><head>	<meta charset="utf-8">	<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">	<title>改进版圣杯布局</title>	<style type="text/css">	body {background-color: #ffffff; font-size:14px;}	#hd, #ft {padding:20px 3px; background-color: #cccccc; text-align: center;}	.bd-lft, .bd-rgt, .bd-3-lr, .bd-3-ll, .bd-3-rr {margin:10px 0; }	.main {background-color:#ececec;}	.main-wrap {background-color: #03a9f4; color:#ffffff; min-width:200px;}	.aside, .aside-1, .aside-2 {background-color: #00bcd4; color:#ffffff;}	p {margin:0; padding:20px; text-align: center;}			/* 左侧栏固定宽度,右侧自适应 */	.bd-lft {	    zoom:1;	    overflow:hidden;	}	.bd-lft .aside {	    float:left;	    width:200px;	    margin-left:-100%; /*= -100%*/	}	.bd-lft .main {	    float:left;	    width:100%;	}	.bd-lft .main-wrap {	    margin-left: 210px;	}	/* 右侧栏固定宽度,左侧自适应 */	.bd-rgt {	    zoom:1;	    overflow:hidden;	}	.bd-rgt .aside {	    float:left;	    width:200px;	    margin-left:-200px; /* = -this.width */	}	.bd-rgt .main {	    float:left;	    width:100%;	}	.bd-rgt .main-wrap {	    margin-right: 210px;	}	/* 左中右 三栏自适应 */	.bd-3-lr {	    zoom:1;	    overflow:hidden;	}	.bd-3-lr .main {	    float:left;	    width:100%;	}	.bd-3-lr .main-wrap {		margin: 0 210px 0 210px;	}	.bd-3-lr .aside-1 {		float: left;		width:200px;		margin-left: -100%;	}	.bd-3-lr .aside-2 {		float: left;		width:200px;		margin-left: -200px;	}	/* 都在左边,右侧自适应 */	.bd-3-ll {	    zoom:1;	    overflow:hidden;	}	.bd-3-ll .main {		float:left;	    width:100%;	}	.bd-3-ll .main-wrap {		margin-left:420px;	}	.bd-3-ll .aside-1 {		float: left;		width:200px;		margin-left: -100%;	}	.bd-3-ll .aside-2 {		float: left;		width:200px;		margin-left: -100%;		position:relative;		left: 210px;	}	/* 都在右边,左侧自适应 */	.bd-3-rr {	    zoom:1;	    overflow:hidden;	}	.bd-3-rr .main {		float:left;	    width:100%;	}	.bd-3-rr .main-wrap {		margin-right:420px;	}	.bd-3-rr .aside-1 {		float: left;		width:200px;		margin-left: -410px;	}	.bd-3-rr .aside-2 {		float: left;		width:200px;		margin-left: -200px;	}	</style></head><body>	<div id="hd">头部</div>		<div class="bd-lft">		<div class="main">			<div class="main-wrap">				<p>主内容栏自适应宽度</p>
                    <div class="aritcle_card">
                        <a class="aritcle_card_img" href="/ai/1496">
                            <img src="https://img.php.cn/upload/ai_manual/000/969/633/68b7a456e0374854.png" alt="PhotoAid Image Upscaler">
                        </a>
                        <div class="aritcle_card_info">
                            <a href="/ai/1496">PhotoAid Image Upscaler</a>
                            <p>PhotoAid出品的免费在线AI图片放大工具</p>
                            <div class="">
                                <img src="/static/images/card_xiazai.png" alt="PhotoAid Image Upscaler">
                                <span>52</span>
                            </div>
                        </div>
                        <a href="/ai/1496" class="aritcle_card_btn">
                            <span>查看详情</span>
                            <img src="/static/images/cardxiayige-3.png" alt="PhotoAid Image Upscaler">
                        </a>
                    </div>
                			</div>		</div>		<div class="aside">			<p>侧边栏固定宽度</p>		</div>	</div>	<div class="bd-rgt">		<div class="main">			<div class="main-wrap">				<p>主内容栏自适应宽度</p>			</div>		</div>		<div class="aside">			<p>侧边栏固定宽度</p>		</div>	</div>	<div class="bd-3-lr">		<div class="main">			<div class="main-wrap">				<p>主内容栏自适应宽度</p>			</div>		</div>		<div class="aside-1">			<p>侧边栏1固定宽度</p>		</div>		<div class="aside-2">			<p>侧边栏2固定宽度</p>		</div>	</div>	<div class="bd-3-ll">		<div class="main">			<div class="main-wrap">				<p>主内容栏自适应宽度</p>			</div>		</div>		<div class="aside-1">			<p>侧边栏1固定宽度</p>		</div>		<div class="aside-2">			<p>侧边栏2固定宽度</p>		</div>	</div>	<div class="bd-3-rr">		<div class="main">			<div class="main-wrap">				<p>主内容栏自适应宽度</p>			</div>		</div>		<div class="aside-1">			<p>侧边栏1固定宽度</p>		</div>		<div class="aside-2">			<p>侧边栏2固定宽度</p>		</div>	</div>		<div id="ft">底部</div></body></html>
登录后复制



HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号