首先我们来看什么是自适应布局?
所谓自适应布局我们从百度上可以搜到如下的定义自适应设计指能使网页自适应显示在不同大小终端设备上新网页设计方式及技术。简单的来说自适应就是让同一个页面自动适应不同大小的设备,从而解决为不同设备提供不同版本的页面问题。
知道了自适应布局是怎么一回事后,那么我们就来看一看自适应布局该如何实现?
页面的自适应布局分为高度自适应和宽度自适应,实现方式其实有挺多的,下面我们就来以三列布局为例来看看自适应布局的实现方式。
一、自适应布局之高度自适应
高度自适应就是把每个模块设置为绝对定位,然后设置中间自适应的模块的top和bottom属性的值分别为头部模块和底部模块的高,然后中间模块的高度就自适应了。
高度自适应布局代码如下:
<body>
<divclass="top">120px</div>
<divclass="main">自适应</div>
<divclass="bottom">120px</div>
</body>
.top{
width:100%;
height:120px;
position:absolute;
background-color:greenyellow;
}
.main{
position:absolute;
width:100%;
top:120px;
bottom:120px;
background-color:pink;
height:auto;
}
.bottom{
position:absolute;
bottom:0;//别漏了
width:100%;
height:120px;
background-color:greenyellow;
}
高度自适应布局效果如下:
2345截图20180927135634.png
二、自适应布局之宽度自适应
宽度自适应有三种方法,分别是用绝对定位;利用margin,中间模块先渲染;自身浮动。
下面我们来分别看看这三种方法实现的自适应布局(三列)
1、利用绝对定位来设置宽度自适应布局
说明:针对自适应模块使用绝对定位,在把left和right设置为左右两列的宽,其实原理和高度自适应一样,另外左右两列分别左右浮动。
绝对定位设置宽度自适应布局代码如下:
<body>
<divclass="left">200px</div>
<divclass="main">自适应</div>
<divclass="right">200px</div>
</body>
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:pink;
display:inline;
}
宽度自适应布局效果如下:
2345截图20180927140338.png
2、利用margin,中间模块先渲染来设置宽度自适应布局
说明:中间一列优先渲染的自适应三列布局,优先渲染(加载)的关键:内容在html里面必须放在前面。自适应的div必须放在left和right前面且包含在一个父div里。父div,left和right模块都向左浮动,然后对自适应的div(就是父div里的子div)设置margin:0200px,然后对left的margin-left的属性值设置为100%的负数,就是margin-left:-100%;对right的margin-left的属性值设置为自身宽度的负数,就是margin-left:-200px。
注意:自适应的div必须放在left和right前面且包含在一个父div里。
利用margin,中间模块先渲染设置宽度自适应布局的代码如下:
<body>
<divclass="main"><!--看清楚,这里用一个父div包住-->
<divclass="content">自适应</div>
</div>
<divclass="left">200px</div>
<divclass="right">200px</div>
</body>
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:0200px;
background-color:pink;
height:100%;
}
.left,
.right{
width:200px;
height:100%;
float:left;
background-color:greenyellow;
}
.left{
margin-left:-100%;//important
}
.right{
margin-left:-200px;//important
}


本文转载自中文网
本文转载自中文网
如需转载,请注明文章出处和来源网址:http://www.divcss5.com/html/h54648.shtml