码迷,mamicode.com
首页 > Web开发 > 详细

css教程:css自适应布局方法

时间:2016-04-07 23:08:07      阅读:355      评论:0      收藏:0      [点我收藏+]

标签:

在进行web前端项目开发(http://www.maiziedu.com/course/web-px/时,通常情况下会对浏览器进行自适应布局,自适应布局分两类:高度和宽度,方法有很多,我用三列布局举例,我就列几个通俗易懂的例子呗,懂了三列的,两列的原理一样,呵呵哒。
效果图如下:高度自适应——宽度自适应
1,高度自适应布局
      原理就是把每个模块设置为绝对定位,然后设置中间自适应的模块的topbottom属性的值分别为头部模块和底部模块的高,然后中间模块的高度就自适应了。代码如下:
html代码:
<body>
        <div class="top">
            120px
        </div>
        <div class="main">
            自适应
        </div>
        <div class="bottom">
            120px
        </div></body>
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,用绝对定位来设置宽度自适应布局,原理:针对自适应模块使用绝对定位,在把leftright设置为左右两列的宽,其实原理和高度自适应一样,另外左右两列分别左右浮动。
    html代码:
<body>
        <div class="left">
            200px
        </div>
        <div class="main">
            自适应
        </div>
        <div class="right">
            200px
        </div></body>
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必须放在leftright前面且包含在一个父div里。父divleftright模块都向左浮动,然后对自适应的div(就是父div里的子div)设置margin0 200px,然后对leftmargin-left的属性值设置为100%的负数,就是margin-left-100%;对rightmargin-left的属性值设置为自身宽度的负数,就是margin-left-200px
注意:自适应的div必须放在leftright前面且包含在一个父div里。
html代码:
<body>
        <div class="main"> <!--看清楚,这里用一个父div包住-->
            <div class="content">
                自适应
            </div>
        </div>
        <div class="left">
            200px
        </div>
        <div class="right">
            200px
        </div></body>
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中放在leftright后面。
html代码:
<body>        
        <div class="left">
            200px
        </div>
        <div class="right">
            200px
        </div>
        <div class="main">
            自适应
        </div></body>
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;
}

css教程:css自适应布局方法

标签:

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
jiangjie190
加入时间:2016-02-19
  关注此人  发短消息
文章分类
jiangjie190”关注的人------(0
jiangjie190”的粉丝们------(0
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!