• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > CSS3的Flexible Boxes详细使用教程

CSS3的Flexible Boxes详细使用教程

作者:classicemi 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含CSS3,Flexible,Boxes等相关知识,classicemi 希望在学习及工作中可以帮助到您

Flexible Box是什么?Flexible意为可伸缩的,Box意为盒子,可以理解为一种新式的盒模型——伸缩盒模型。由CSS3规范提出,这是在原有的大家非常熟悉的block, inline-block, inline的基础上延伸出的新一代布局模式。
浏览器兼容性

作为非常现实的开发者,是否对一个新技术进行关注,首先要考虑它的浏览器兼容性如何。我们的伸缩盒模型的浏览器兼容性看起来还是相当不错的。

2015729175809456.jpg (600×370)

可以看到,现代浏览器基本上都支持了,IE10开始也支持了(IE和Safari分别加-ms-和-webkit-前缀即可),移动端的支持情况也比较良好,唯一不支持的平台只有Opera了,咱不带他玩→_→

因此,奥巴马同志说:伸缩盒模型是好的,有前途的。(嗯嗯~)
伸缩盒基本概念

伸缩盒的最大特点或者说优点就在于它考虑到了现今高昂的房价和人民日益增长的住宅需求之间的矛盾,房屋面积是有限的,但是我们的伸缩盒能够最合理最高效地把房子分给大家。面积多了,就给大家伙多分点;面积小了,就让各位挤一挤少分点,总而言之不会让任何一个人露宿街头的(overflow)!

既然我们提到了房子和住户的关系,那么住户的排列自然需要沿一定的方向。对于块级元素来说,布局的延伸方向是自上而下的,也就是纵向。而对于行内元素来说,布局延伸方向是自左往右的,也就是横向。而伸缩盒呢,它的方向是可变的,既能纵向延伸,也能横向舒展,这取决于你的设置了。
伸缩盒模型基本术语

伸缩盒模型的思想和普通的块级元素和行内元素的布局思想有较大的不同,它引入了一些新的概念和术语,通过下面这张图来了解一下:
2015729175849323.png (563×333)

Flex container 伸缩盒容器
这就是用来分的房子,这是一间神奇的房子,要让它变得神奇,将display属性声明为flex或inline-flex即可~

Flex item 伸缩项
房子里的居民,他们都会占有自己应得的住房面积。

为了形象说明,我们用代码来解释。

  1. <div class="container">  
  2.   <div class="item item-1">item 1</div>  
  3.   <div class="item item-2">item 2</div>  
  4.   <div class="item item-3">item 3</div>  
  5. </div>  

CSS设置为:

  1. .container {   
  2.   display: flex;   
  3.   width: 300px;   
  4.   height: 100px;   
  5.   ...   
  6. }  

在这里display: inline-flex;好像也可以。
对于其中的伸缩项元素,我们需要给他们事先安排好住房面积比例,我们就用最简单最健康的1:1:1吧~我们将比例声明在flex属性里

  1. .item-1 {   
  2.   flex: 1;   
  3.   ...   
  4. }   
  5. .item-2 {   
  6.   flex: 1;   
  7.   ...   
  8. }   
  9. .item-3 {   
  10.   flex: 1;   
  11.   ...   
  12. }  

2015729175944765.jpg (303×103)

我们的大房子被完美地平分成三个隔间了,三家平分房租!

如果有人想住大点的房子,我们直接改变flex的比例即可:

  1. .item-1 {   
  2.   flex: 1;   
  3.   ...   
  4. }   
  5. .item-2 {   
  6.   flex: 1;   
  7.   ...   
  8. }   
  9. .item-3 {   
  10.   flex: 2;   
  11.   ...   
  12. }  

2015729180014256.jpg (303×103)

是不是很方便?

Axes 轴
我们可以看到,图中有两条轴,分别标注了主轴和次轴(垂直于主轴)。然而实际上哪一条是主轴并不确定,是由我们来规定的。
1. flex-direction 此属性规定哪条轴为主轴。
2. justify-content 此属性设置了伸缩项在主轴方向上的排列方式,这个稍后解释。
3. align-items 此属性和上面的justify-content相对,表示伸缩项在次轴上的排列方式。
4. align-self 此属性规定某一个特定的伸缩项元素在次轴上的布局方式,在某个元素上设置该属性会覆盖它的align-items属性。也就是这个属性会让某个元素更有个性,不走寻常路~

flex-direction
当我们不想沿着默认的方向分房子的时候,我们可以改变flex-direction属性的值来改变主轴和方向,该属性默认的取值为row;

您可能想查找下面的文章:

  • 使用CSS3制作一个简单的进度条(demo)
  • 利用CSS3伪元素实现逐渐发光的方格边框
  • CSS3实现内凹圆角的实例代码
  • 利用HTML5+CSS3实现3D转换效果实例详解
  • css3+伪元素实现鼠标移入时下划线向两边展开的效果
  • CSS3实现自定义Checkbox特效实例代码
  • 总结30个CSS3选择器
  • CSS3模拟动画下拉菜单效果
  • CSS3动画:5种预载动画效果实例
  • CSS3 仿微信聊天小气泡实例代码

相关文章

  • 2017-08-06一款基于css3和jquery实现的动画显示弹出层按钮教程
  • 2017-08-06CSS属性探秘系列(五):min-width
  • 2017-08-06css自动换行 防止撑破div影响排版
  • 2017-08-06纯CSS搞定按钮、链接点击时的虚线
  • 2017-08-06纯CSS无表达式实现未知尺寸图片等比缩放(支持IE7及以上)
  • 2017-08-06实现div垂直居中的display:table-cell方法示例介绍
  • 2017-08-06ie-css3.htc 让IE6, 7, and 8也支持box-shadow
  • 2017-08-06不同CSS技术及其CSS性能之间的差异
  • 2017-08-06Css Reset 复位相关资料整理
  • 2017-08-06简要讲解CSS中的类型选择器、ID选择器、类选择器

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • css美化表格让其隔行变色显示
    • CSS 文字加阴影变3D效果演示
    • CSS3属性background-size使用指南
    • 怎样对齐文本框和图像(image)按钮实现三点一线
    • CSS 优先级使用技巧
    • IE下textarea中font-size值很大时文字不显示的解决方法
    • RoundedCornr 生成圆角图片的好用的简单工具
    • css 的border属性改变hr颜色小示例
    • css实现适用于团购网站的橙色导航菜单代码
    • css背景色透明 内容不透明的解决方法(兼容所有浏览器)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有