CSS3弹性盒模型开发笔记(一)


Posted in HTML / CSS onApril 26, 2016

弹性盒模型(Flexible Box Moudle),该模型用于决定元素在盒子中的分布方式以及处理盒子的可用空间。这与XUL(Firefox浏览器的用户交互语言)相似,其他语言也使用相同的盒模型。如XAML,GladeXML等。通过弹性盒模型,可以轻松地创建自适应浏览器窗口的流动布局或自适应字体大小的弹性布局。

兼容性:弹性盒模型规范是W3C标准化组织于2009年发布的,目前还没有主流浏览器对其进行支持,不过采用Webkit和Mozilla渲染引擎的浏览器都自定义了一套私有属性,用来支持弹性盒模型。

采用Webkit渲染引擎的浏览器主要包括Safari和Chrome浏览器,该引擎支持以-webkit为前缀的私有属性。

Mozilla渲染引擎的浏览器主要包括Firefox浏览器,该引擎支持以-moz为前缀的私有属性。

相关属性:

box-align:定义子元素在盒子垂直方向上的空间分配方式
box-direction:定义盒子的显示顺序
box-flex:定义子元素在盒子内的自适应尺寸
box-flex-group:定义自适应子元素群组
box-lines:定义子元素分列显示
box-ordinal-group:定义子元素在盒子内的显示位置
box-orient:定义盒子分部的坐标轴
box-pack:定义子元素在盒子内水平方向的空间分配方式

box-orient属性

该属性可用于定义盒子元素内部的流动布局方向.在使用弹性盒子模型时,需要先把父容器的display属性设置为box或者inline-box。
语法:

box-orient:horizontal | vertail | inline-axis | block-axis | inherit

取值简单说明:

horizontal:盒子元素从左到右在一条水平线上显示它的子元素。

vertail:盒子元素从上到下在一条垂直线上显示它的子元素。

inline-axis:盒子元素沿着内联轴显示它的子元素。

block-axis:盒子元素沿着块轴显示它的子元素。

实战体验:设计多栏布局

html代码:

XML/HTML Code复制内容到剪贴板
  1. <div id="box">  
  2.     <div id="box0"><img src="images/web_01.gif" /></div>  
  3.     <div id="sub-box">  
  4.         <div id="box1"><img src="images/web_02.gif" /></div>  
  5.         <div id="box2"><img src="images/web_03.gif" /></div>  
  6.         <div id="box3"><img src="images/web_04.gif" /></div>  
  7.     </div>  
  8. </div>  
  9.   

CSS3代码:

CSS Code复制内容到剪贴板
  1. <style type="text/css">   
  2. body{/*文档样式*/  
  3.     margin:0;padding:0px;/*清除页边距*/  
  4.     text-align:center;/*文档居中对齐*/  
  5.     background:#170843;   
  6. }   
  7. #box{   
  8.     margin:auto;/*文档居中对齐*/  
  9.     text-align:center;   
  10.     width:975px;   
  11. }   
  12. /*定制各个栏目的宽度*/  
  13. #box1{width:185px;}   
  14. #box2{width:601px;}   
  15. #box3{width:189px;}   
  16. /*定制子包含框的盒子显示,其包含的元素水平流动*/  
  17. #sub-box{   
  18.     display:-moz-box;   
  19.     display:-webkit-box;   
  20.     display:box;   
  21.     box-orient:horizontal;   
  22.     -moz-box-orient:horizontal;   
  23.     -webkit-box-orient:horizontal;     
  24. }   
  25. </style>   

演示效果:

CSS3弹性盒模型开发笔记(一)

box-direction属性

box-direction属性可以改变盒子元素中内部元素的流动顺序,该属性基本语法:

box-direction:normal | reverse | inherit

取值简单说明:

normal:正常显示顺序,即如果盒子元素的box-origent属性值为horizontal,则其包含的子元素按照从左到右的顺序显示,即每个子元素的左边总是靠近前一个子元素的右边;如果盒子元素的box-origent属性值设置为vertical,则其包含的子元素按照从上到下的顺序显示。

reverse:反向显示,盒子所包含的子元素的显示顺序将于normal相反。

inherit:继承上级元素的显示顺序。

实战体验:反向布局网页(以上面的案例为基础):

CSS3代码:

CSS Code复制内容到剪贴板
  1. <style>   
  2. body{   
  3.     margin:0;padding:0px;   
  4.     text-align:center;   
  5.     background:#170843;   
  6. }   
  7. #box{   
  8.     margin:auto;   
  9.     text-align:center;   
  10.     width:975px;   
  11. }   
  12. #box1{width:185px;}   
  13. #box2{width:601px;}   
  14. #box3{width:189px;}   
  15. #sub-box{   
  16.     display:-moz-box;   
  17.     display:-webkit-box;   
  18.     display:box;   
  19.     box-orient:horizontal;   
  20.     -moz-box-orient:horizontal;   
  21.     -webkit-box-orient:horizontal;     
  22.     box-direction:reverse;   
  23.     -moz-box-direction:reverse;   
  24.     -webkit-box-direction:reverse;   
  25. }   
  26. </style>   
  27.   

演示效果:

CSS3弹性盒模型开发笔记(一)

box-ordinal-group属性

  box-direction属性可以改变盒子内部元素的流动顺序,而box-ordinal-group属性能够设置每个子元素在盒子中的具体显示位置,语法如下:

box-ordinal-group:<integer>

取值说明:

属性值是一个自然数,从1 开始,用来设置子元素的位置符号。子元素的分布将根据这个属性值从小到大进行排列。在默认情况下,子元素将根据元素的位置进行排列。
注意:如果没有指定box-ordinal-group属性值的子元素,则其序号默认都为1,并且序号相同的元素将按照他们在文档中的加载的顺序进行排列。

实战体验:垂直网页布局

HTML代码:

XML/HTML Code复制内容到剪贴板
  1. <div id="box">  
  2.     <div id="box1"><img src="images/web1_01.gif" /></div>  
  3.     <div id="box2"><img src="images/web1_02.gif" /></div>  
  4.     <div id="box3"><img src="images/web1_03.gif" /></div>  
  5.     <div id="box4"><img src="images/web1_04.gif" /></div>  
  6. </div>  
  7.   

CSS3代码:

CSS Code复制内容到剪贴板
  1. <style type="text/css">   
  2. body {   
  3.     margin:0;   
  4.     padding:0;   
  5.     text-align:center;   
  6.     background:#d9bfe8;   
  7. }   
  8. #box {   
  9.     margin:auto;   
  10.     text-align:left;   
  11.     width:988px;   
  12. }   
  13. /*定义盒形显示及盒内元素垂直显示*/  
  14. #box {   
  15.     display : -moz-box;   
  16.     display : -webkit-box;   
  17.     display : box;   
  18.     box-orient:vertical;   
  19.     -moz-box-orient:vertical;   
  20.     -webkit-box-orient:vertical;   
  21. }   
  22. /*根据网页内容的现实需要,借助弹性盒模型调整各个板块的显示顺序*/  
  23. #box1 {/*设置第一个元素显示在第二个位置*/  
  24.     -moz-box-ordinal-group : 2;/*兼容Mozilla Gecko引擎*/  
  25.     -webkit-box-ordinal-group : 2;/*兼容Webkit引擎*/  
  26.     box-ordinal-group : 2;/*标准用法*/  
  27. }   
  28. #box2 {/*设置第二个元素显示在第三个位置*/  
  29.     -moz-box-ordinal-group : 3;/*兼容Mozilla Gecko引擎*/  
  30.     -webkit-box-ordinal-group : 3;/*兼容Webkit引擎*/  
  31.     box-ordinal-group : 3;/*标准用法*/  
  32. }   
  33. #box3 {/*设置第三个元素显示在第一个位置*/  
  34.     -moz-box-ordinal-group : 1;/*兼容Mozilla Gecko引擎*/  
  35.     -webkit-box-ordinal-group : 1;/*兼容Webkit引擎*/  
  36.     box-ordinal-group : 1;/*标准用法*/  
  37. }   
  38. #box4 {/*设置第四个元素显示在第四个位置*/  
  39.     -moz-box-ordinal-group : 4;/*兼容Mozilla Gecko引擎*/  
  40.     -webkit-box-ordinal-group : 4;/*兼容Webkit引擎*/  
  41.     box-ordinal-group : 4;/*标准用法*/  
  42. }   
  43. </style>   
  44.   

演示效果:

CSS3弹性盒模型开发笔记(一)

以上就是关于CSS3弹性盒模型基础开发知识总结,希望对大家认识CSS3弹性盒模型有所帮助。

本文地址:http://blog.csdn.net/lovejulyer/article/details/51231951

HTML / CSS 相关文章推荐
CSS3实现任意图片lowpoly动画效果实例
May 11 HTML / CSS
CSS3动画animation实现云彩向左滚动
May 09 HTML / CSS
详解CSS3选择器的使用方法汇总
Nov 24 HTML / CSS
css3实现3D文本悬停改变效果的示例代码
Jan 16 HTML / CSS
使用CSS3实现SVG路径描边动画效果入门教程
Oct 21 HTML / CSS
HTML5中通过li-canvas轻松实现单图、多图、圆角图绘制,单行文字、多行文字等
Nov 30 HTML / CSS
html5 Canvas画图教程(7)—canvas里画曲线之quadraticCurveTo方法
Jan 09 HTML / CSS
利用HTML5实现使用按钮控制背景音乐开关
Sep 21 HTML / CSS
Html5中localStorage存储JSON数据并读取JSON数据的实现方法
Feb 13 HTML / CSS
canvas进阶之贝塞尔公式推导与物体跟随复杂曲线的轨迹运动
Jan 10 HTML / CSS
使用html2canvas.js实现页面截图并显示或上传的示例代码
Dec 18 HTML / CSS
Html5 webview元素定位工具的实现
Aug 07 HTML / CSS
CSS3弹性盒模型开发笔记(三)
Apr 26 #HTML / CSS
浅析两列自适应布局的3种思路
May 03 #HTML / CSS
CSS3 3D位移translate效果实例介绍
May 03 #HTML / CSS
详解CSS的border边框属性及其在CSS3中的新特性
May 10 #HTML / CSS
CSS3中border-radius属性设定圆角的使用技巧
May 10 #HTML / CSS
CSS3使用多列制作瀑布流
May 10 #HTML / CSS
使用CSS3的rem属性制作响应式页面布局的要点解析
May 24 #HTML / CSS
You might like
PHP缓存技术的使用说明
2011/08/06 PHP
有道搜索和IP138的IP的API接口(PHP应用)
2012/11/29 PHP
详解PHP执行定时任务的实现思路
2015/12/21 PHP
解决遍历时Array.indexOf产生的性能问题
2012/07/03 Javascript
JavaScript高级程序设计 阅读笔记(二十) js错误处理
2012/08/14 Javascript
js去字符串前后空格5种实现方法及比较
2013/04/03 Javascript
JS保存和删除cookie操作 判断cookie是否存在
2013/11/13 Javascript
javascript将相对路径转绝对路径示例
2014/03/14 Javascript
jQuery判断当前点击的是第几个li的代码
2014/09/26 Javascript
jQuery中:gt选择器用法实例
2014/12/29 Javascript
javascript将数字转换整数金额大写的方法
2015/01/27 Javascript
JavaScript中字面量与函数的基本使用知识
2015/10/20 Javascript
微信小程序 本地数据存储实例详解
2017/04/13 Javascript
vue子组件使用自定义事件向父组件传递数据
2017/05/27 Javascript
webpack配置之后端渲染详解
2017/10/26 Javascript
微信小程序遍历Echarts图表实现多个饼图
2019/04/25 Javascript
vue.js实现简单的计算器功能
2020/02/22 Javascript
Python中让MySQL查询结果返回字典类型的方法
2014/08/22 Python
Python中的深拷贝和浅拷贝详解
2015/06/03 Python
横向对比分析Python解析XML的四种方式
2016/03/30 Python
对python添加模块路径的三种方法总结
2018/10/16 Python
Python实现多属性排序的方法
2018/12/05 Python
Python上下文管理器全实例详解
2019/11/12 Python
django-xadmin根据当前登录用户动态设置表单字段默认值方式
2020/03/13 Python
让IE6、IE7、IE8支持CSS3的脚本
2010/07/20 HTML / CSS
将HTML5 Canvas的内容保存为图片借助toDataURL实现
2013/05/20 HTML / CSS
学生周末长期请假条
2014/02/15 职场文书
工伤死亡理赔协议书
2014/10/20 职场文书
2014年会计个人工作总结
2014/11/24 职场文书
2014离婚协议书范文(3篇)
2014/11/29 职场文书
五四青年节比赛演讲稿
2015/03/18 职场文书
2015学校六五普法工作总结
2015/04/22 职场文书
2015秋季开学典礼演讲稿
2015/07/16 职场文书
会计入职心得体会
2016/01/22 职场文书
导游词之湖北武当山
2019/09/23 职场文书
springcloud之Feign超时问题的解决
2021/06/24 Java/Android