登录  /  注册
DIV+CSS自适应布局_html/css_WEB-ITnose
php中文网
发布: 2016-06-24 11:21:34
原创
945人浏览过

自适应布局分两类:高度和宽度,方法有很多,我用三列布局举例,我就列几个通俗易懂的例子呗,懂了三列的,两列的原理一样,呵呵哒。

效果图如下:高度自适应——宽度自适应

1,高度自适应布局

原理就是把每个模块设置为绝对定位,然后设置中间自适应的模块的top和bottom属性的值分别为头部模块和底部模块的高,然后中间模块的高度就自适应了。代码如下:

html代码:

        
120px
自适应
120px
登录后复制

css代码:

.top{    width: 100%;    height: 120px;    position: absolute;    background-color: greenyellow;    }.main{    position: absolute;    width: 100%;    top: 120px;    bottom: 120px;    background-color: azure;    height: auto;}.bottom{    position: absolute;    bottom: 0;//别漏了    width: 100%;    height: 120px;    background-color:greenyellow ;}
登录后复制

2,宽度自适应,有三种方法,分别是用绝对定位;利用margin,中间模块先渲染;自身浮动。

a,用绝对定位来设置宽度自适应布局,原理:针对自适应模块使用绝对定位,在把left和right设置为左右两列的宽,其实原理和高度自适应一样,另外左右两列分别左右浮动。

html代码:

        
200px
自适应
200px
登录后复制

css代码:

html,body {    margin: 0;    height: 100%;    padding: 0;    font-size: 30px;    font-weight: 500;    text-align: center;}.left,.right {    width: 200px;    display: inline;    height: 100%;    background-color: greenyellow;}.left {    float: left;}.right {    float: right;}.main {    position: absolute;    left: 200px;    right: 200px;    height: 100%;    background-color: azure;    display: inline;}
登录后复制

b,中间一列优先渲染的自适应三列布局,优先渲染(加载)的关键:内容在html里面必须放在前面。自适应的div必须放在left和right前面且包含在一个父div里。父div,left和right模块都向左浮动,然后对自适应的div(就是父div里的子div)设置margin:0 200px,然后对left的margin-left的属性值设置为100%的负数,就是margin-left:-100%;对right的margin-left的属性值设置为自身宽度的负数,就是margin-left:-200px。

注意:自适应的div必须放在left和right前面且包含在一个父div里。

html代码:

        
自适应
200px
200px
登录后复制

css代码:

html,body {    margin: 0;    height: 100%;    padding: 0;    font-size: 30px;    font-weight: 500;    text-align: center;}.main {    width: 100%;    height: 100%;    float: left;}.main .content {    margin: 0 200px;    background-color: azure;    height: 100%;}.left,.right {    width: 200px;    height: 100%;    float: left;    background-color: greenyellow;}.left {    margin-left: -100%; //important}.right {    margin-left: -200px; //important}
登录后复制

c,自身浮动,原理:中间列设置margin属性,就是把左右列分别左右浮动。注意:使用这个方法布局自适应的话,必须把自适应的那一列在html中放在left和right后面。

html代码:

                
200px
200px
自适应
登录后复制

css代码:

html,body {    margin: 0;    height: 100%;    padding: 0;    font-size: 30px;    font-weight: 500;    text-align: center;}.main {    margin: 0 200px;    height: 100%;    background-color: azure;}.left,.right {    width: 200px;    height: 100%;    background-color: greenyellow;}.left {    float: left;}.right {    float: right;}
登录后复制

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

Copyright 2014-2023 //m.sbmmt.com/ All Rights Reserved | 苏州跃动光标网络科技有限公司 | 苏ICP备2020058653号-1

 | 本站CDN由 数掘科技 提供

登录PHP中文网,和优秀的人一起学习!
全站2000+教程免费学