CSS3弹性伸缩布局之box布局


Posted in HTML / CSS onJuly 12, 2016

CSS3弹性伸缩布局简介

2009年,W3C提出了一种崭新的方案----Flex布局(即弹性伸缩布局),它可以简便、完整、响应式地实现各种页面布局,包括一直让人很头疼的垂直水平居中也变得很简单地就迎刃而解了。但是这个布局方式还处于W3C的草案阶段,并且它还分为旧版本、新版本以及混合过渡版本三种不同的编码方式。其中混合过渡版本主要是针对IE10做了兼容。目前flex布局用得比较多的还是在移动端的布局,所以本次主要讲解一下旧版本和新版本在移动端使用的各个知识点,让大家对神秘的flex布局熟悉起来。

旧版本(box)

首先看一下浏览器兼容情况:

CSS3弹性伸缩布局之box布局

PS:浏览器兼容数据不一定很准确,不过相差不大。

下面将通过一个简单的实例来讲解旧版本的各个属性:

html代码:

XML/HTML Code复制内容到剪贴板
  1. <div>  
  2.     <p>发生过的空间还是看价格哈健康啊水果和卡刷卡更何况规划哈萨空给</p>  
  3.     <p>发生过的空间还是看价格哈健康啊水果和卡刷卡更何况规划哈萨</p>  
  4.     <p>发生过的空间还是看价格哈健康啊水果和卡刷卡更何况规划</p>  
  5. </div>  

可以看到我们这个例子是很简单的,一个div元素内包含三个p元素,它们都是块元素(block)。接下来给段落加一些基础的样式:

CSS Code复制内容到剪贴板
  1. p{   
  2.     width:150px;   
  3.     border:3px solid lightblue;   
  4.     background:lightgreen;   
  5.     padding:5px;   
  6.     margin:5px;   
  7. }  

此时刷新网页看到的结果是这样的:

CSS3弹性伸缩布局之box布局

这个结果很正常吧!OK,现在我们给div元素设置为box,看看有什么变化:

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4. }  

我们再次刷新网页,结果是这样的:

CSS3弹性伸缩布局之box布局

看到了吧,现在每一个p元素都变成一个box了,这就是弹性布局的神奇所在!

在上面中,我们将div元素的display设置为box,这就是旧版本的弹性布局。对于比较旧的浏览器版本,我们需要加上-webkit-前缀。

旧版本的弹性布局有两个属性值:

box : 将容器盒模型作为块级弹性伸缩盒显示 inline-box : 将容器盒模型作为内联级弹性伸缩盒显示

PS:我们知道块级它是占用整行的,比如div元素;而内联级不占用整行,比如span元素。但是我们设置了整个盒子,他们都不占用,保持一致。就像我们上面的例子一样,给div元素设置了盒子,那么div元素里面的p元素就不占用了。

下面介绍旧版本弹性布局的各个属性:

box-orient 属性

box-orient属性主要实现盒子内部元素的流动方向。

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4.     -webkit-box-orient:vertical;   
  5.     box-orient:vertical;   
  6. }  

此时的结果就是垂直排列:

CSS3弹性伸缩布局之box布局

此属性的属性值有:

horizontal : 伸缩项目从左到右水平排列 vertical : 伸缩项目从上到下垂直排列inline-axis : 伸缩项目沿着内联轴排列显示block-axis : 伸缩项目沿着块轴排列显示

大家不妨试一下:horizontal 和 inline-axis 都是水平排列,而vertical 和 block-axis 都是垂直排列。

box-direction属性

box-direction 属性主要是设置伸缩容器中的流动顺序。

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4.     -webkit-box-direction:reverse;   
  5.     box-direction:reverse;   
  6. }  

这样我们的排序就是反序的了,运行结果为:

CSS3弹性伸缩布局之box布局

此属性的属性值有:

normal : 正常顺序,默认值 reverse : 反序

box-pack属性

box-pack 属性用于伸缩项目的分布方式。

此属性的属性值有:

start : 伸缩项目以起始点靠齐 end : 伸缩项目以结束点靠齐 center : 伸缩项目以中心点靠齐 justify : 伸缩项目平局分布

下面我们都试一下各个属性值的效果:

1.start属性值

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     -webkit-box-pack:start;   
  3.     box-pack:start;   
  4. }  

这个就是默认靠齐方式:

CSS3弹性伸缩布局之box布局

2.end属性值

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     -webkit-box-pack:   
  3. end   
  4. ;   
  5.     box-pack:   
  6. end   
  7. ;   
  8. }  

这个就是以结束点靠齐:

CSS3弹性伸缩布局之box布局

3.center属性值

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     -webkit-box-pack:   
  3. center   
  4. ;   
  5.     box-pack:   
  6. center   
  7. ;   
  8. }  

这就是居中对齐效果:

CSS3弹性伸缩布局之box布局

4.justify属性值

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     -webkit-box-pack:   
  3. justify   
  4. ;   
  5.     box-pack:   
  6. justify   
  7. ;   
  8. }  

这个就是平均分布效果:

CSS3弹性伸缩布局之box布局

PS:垂直方向上也是一样的原理,但如果height为auto的话,效果将出不来。所以需要给height设置一个定高(最好比默认情况高)。这时,就能看到在垂直方向上的效果了。这里我就不再赘述了。

box-align属性

box-align 属性用来处理伸缩容器的额外空间。

此属性的属性值有:

start : 伸缩项目以顶部为基准,清理下部额外空间 end : 伸缩项目以底部为基准,清理上部额外空间 center : 伸缩项目以中部为基准,平均清理上下部额外空间baseline : 伸缩项目以基线为基准,清理额外的空间stretch : 伸缩项目填充整个容器,默认值

同样的,我们将试一下每个属性值的效果:

1.start属性值

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4.     -webkit-box-align:start;   
  5.     box-align:start;   
  6. }  

效果如下:

CSS3弹性伸缩布局之box布局

2.end属性值

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4.     -webkit-box-align:   
  5. end   
  6. ;   
  7.     box-align:   
  8. end   
  9. ;   
  10. }  

效果如下:

CSS3弹性伸缩布局之box布局

3.center属性值

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4.     -webkit-box-align:   
  5. center   
  6. ;   
  7.     box-align:   
  8. center   
  9. ;   
  10. }  

效果如下:

CSS3弹性伸缩布局之box布局

4.baseline属性值

如果box-orient是内嵌单轴或横向,所有的子元素都置于他们的基线对齐。

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4.     -webkit-box-orient:horizontal;   
  5.     box-orient:horizontal;   
  6.     -webkit-box-align:baseline;   
  7.     box-align:baseline;   
  8. }   

效果如下:

CSS3弹性伸缩布局之box布局

而如果box-orient是块轴或者垂直方向的,那么所有的子元素都将居中垂直排列。

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4.     -webkit-box-orient:   
  5. vertical   
  6. ;   
  7.     box-orient:vertical;   
  8.     -webkit-box-align:baseline;   
  9.     box-align:baseline;   
  10. }  

效果如下:

CSS3弹性伸缩布局之box布局

5.stretch属性值

所有子元素拉伸以填充包含区块。

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4.     -webkit-box-align:   
  5. stretch   
  6. ;   
  7.     box-align:   
  8. stretch   
  9. ;   
  10. }  

效果如下:

CSS3弹性伸缩布局之box布局

box-flex属性

box-flex 属性可以使用浮点数分配伸缩项目的比例。此属性是给容器内的项目设置的,它们会基于父容器的宽度来分配它们所占的比例:

XML/HTML Code复制内容到剪贴板
  1. p:nth-child(1){   
  2.     -webkit-box-flex:1;   
  3.     box-flex:1;   
  4. }   
  5. p:nth-child(2){   
  6.     -webkit-box-flex:3;   
  7.     box-flex:3;   
  8. }   
  9. p:nth-child(3){   
  10.     -webkit-box-flex:1;   
  11.     box-flex:1;   
  12. }  

效果如下:

CSS3弹性伸缩布局之box布局

当然也可以有些项目是固定宽度的,那么其他的项目也会分配剩余的宽度,比如这里第一个p元素设置为固定宽度:

XML/HTML Code复制内容到剪贴板
  1. p:nth-child(2){   
  2.     -webkit-box-flex:2;   
  3.     box-flex:2;   
  4. }   
  5. p:nth-child(3){   
  6.     -webkit-box-flex:1;   
  7.     box-flex:1;   
  8. }  

效果如下:

CSS3弹性伸缩布局之box布局

更多使用情况,大家可以自己慢慢去尝试。

box-ordinal-group 属性

box-ordinal-group 属性可以设置伸缩项目的显示位置。

XML/HTML Code复制内容到剪贴板
  1. p:nth-child(1){   
  2.     -webkit-box-ordinal-group:2;   
  3.     box-ordinal-group:2;   
  4. }   
  5. p:nth-child(2){   
  6.     -webkit-box-ordinal-group:3;   
  7.     box-ordinal-group:3;   
  8. }   
  9. p:nth-child(3){   
  10.     -webkit-box-ordinal-group:1;   
  11.     box-ordinal-group:1;   
  12. }  

效果如下:

CSS3弹性伸缩布局之box布局

可以看到:第一个p元素排在了第二,第二个p元素排在了第三,第三个p元素排在了第一。可以单独给某一个p元素设置此属性,其他项目会按照原来的顺序做变动。

OK,那么旧版本的所有属性就简单的介绍完了,更多结合的用法还是根据需要自己多动手去练习一下。

这里举一个水平垂直居中的例子:

XML/HTML Code复制内容到剪贴板
  1. div{   
  2.     display:-webkit-box;   
  3.     display:box;   
  4.     height:500px;   
  5.     border:1px solid #f00;   
  6.     -webkit-box-pack:center;   
  7.     box-pack:center;   
  8.     -webkit-box-align:center;   
  9.     box-align:center;   
  10. }  

那么效果就是这样的了:

CSS3弹性伸缩布局之box布局

此时我们再给p元素设置一个固定的高度:

XML/HTML Code复制内容到剪贴板
  1. p{   
  2.     width:150px;   
  3.     height:200px;   
  4. }  

那么这时的效果就是:

CSS3弹性伸缩布局之box布局

是不是很轻松就实现了这种效果呢!

小结

好的,到这里旧版本的弹性布局基础知识点就都介绍了一下。由于篇幅过长,怕大家看着疲劳,新版本的弹性布局(flex)我将放在下一篇介绍。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

原文出处:http://www.cnblogs.com/jr1993/p/4751410.html

HTML / CSS 相关文章推荐
50个强大璀璨的CSS3/JS技术运用实例
Feb 27 HTML / CSS
利用CSS3的特性改变文本选中时的颜色
Sep 11 HTML / CSS
使用css3制作登录表单的步骤
Apr 07 HTML / CSS
浅析几个CSS3常用功能的写法
Jun 05 HTML / CSS
CSS3中HSL和HSLA的简单使用示例
Jul 14 HTML / CSS
CSS3之transition实现下划线的示例代码
May 30 HTML / CSS
html5 datalist标签使用示例(自动完成组件)
May 04 HTML / CSS
html5使用canvas绘制文字特效
Dec 15 HTML / CSS
HTML5 Canvas基本线条绘制的实例教程
Mar 17 HTML / CSS
HTML5中的Web Notification桌面通知功能的实现方法
Jul 29 HTML / CSS
iframe与window.onload如何使用详解
May 07 HTML / CSS
CSS3 制作的图片滚动效果
Apr 14 HTML / CSS
使用CSS3代码绘制可爱的Hello Kitty猫
Aug 03 #HTML / CSS
使用css3绘制出各种几何图形
Aug 17 #HTML / CSS
利用CSS3实现自定义滚动条代码分享
Aug 18 #HTML / CSS
纯CSS3实现图片无间断轮播效果
Aug 25 #HTML / CSS
纯CSS3代码实现switch滑动开关按钮效果
Aug 30 #HTML / CSS
CSS3实现跳动的动画效果
Sep 12 #HTML / CSS
利用CSS3的flexbox实现水平垂直居中与三列等高布局
Sep 12 #HTML / CSS
You might like
对于ThinkPHP框架早期版本的一个SQL注入漏洞详细分析
2014/07/04 PHP
php用正则判断是否为数字的方法
2016/03/25 PHP
Laravel的throttle中间件失效问题解决方法
2016/10/09 PHP
php打开本地exe程序,js打开本地exe应用程序,并传递相关参数方法
2018/02/06 PHP
用 JavaScript 迁移目录
2006/12/18 Javascript
用JQuery模仿淘宝的图片放大镜显示效果
2011/09/15 Javascript
jquery+ajax+C#实现无刷新操作数据库数据的简单实例
2014/02/08 Javascript
jquery制作居中遮罩层效果分享
2014/02/21 Javascript
node.js中的path.dirname方法使用说明
2014/12/09 Javascript
日常收藏的jquery技巧
2015/12/02 Javascript
js 创建对象 经典模式全面了解
2016/08/16 Javascript
js 作用域和变量详解
2017/02/16 Javascript
bootstrap table动态加载数据示例代码
2017/03/25 Javascript
利用JS做网页特效_大图轮播(实例讲解)
2017/08/09 Javascript
jQuery实现标签子元素的添加和赋值方法
2018/02/24 jQuery
Mac下通过brew安装指定版本的nodejs教程
2018/05/17 NodeJs
基于vue实现简易打地鼠游戏
2020/08/21 Javascript
[01:59]DOTA2首部纪录片《Free to play》预告片
2014/03/12 DOTA
python命名空间(namespace)简单介绍
2019/08/10 Python
Django模板导入母版继承和自定义返回Html片段过程解析
2019/09/18 Python
django formset实现数据表的批量操作的示例代码
2019/12/06 Python
python分布式计算dispy的使用详解
2019/12/22 Python
使用Tensorflow将自己的数据分割成batch训练实例
2020/01/20 Python
解决Keras 与 Tensorflow 版本之间的兼容性问题
2020/02/07 Python
基于Python-turtle库绘制路飞的草帽骷髅旗、美国队长的盾牌、高达的源码
2021/02/18 Python
用HTML5 实现橡皮擦的涂抹效果的教程
2015/05/11 HTML / CSS
UNDONE手表官网:世界领先的定制手表品牌
2018/11/13 全球购物
Rentalcars.com中国:世界上最大的在线汽车租赁服务
2019/08/22 全球购物
英国计算机商店:Technextday
2019/12/28 全球购物
逻辑链路控制协议
2016/10/01 面试题
写给女朋友的道歉信
2014/01/08 职场文书
优秀技术工人先进材料
2014/02/17 职场文书
祝福语集锦:送给闺蜜的生日祝福语
2019/10/08 职场文书
基于Redis实现分布式锁的方法(lua脚本版)
2021/05/12 Redis
《群青的幻想曲》京力秋树角色PV公开
2022/04/08 日漫
Python实现信息管理系统
2022/06/05 Python