flex学习小结
接触到flex一个多月了,今天做一个学习小结。如果有知识错误或者意见不同的地方。欢迎交流指教。
画外音:先说一下,我是怎么接触到flex布局的。对于正在学习的童鞋们,我建议大家没事可以逛逛网站,看看人家的源代码。至于怎么看?从浏览器已经生成的静态代码看(当然如果该公司的代码在github开源了,那就去github中看吧,也可以fork到自己的托管空间下创建派生自己改着玩。),或者去网站上下一些自己感兴趣的或者差不多效果的代码看。多看demo,多加学习。
一个月前看到国美金融美易理财的界面,网址:m.gomemyc.com/h5/。觉得它的布局很有意思呀,copy到本地,看了一下它的页面代码。发现在列表那边采用了flex方式的布局。然后就开始上网搜呀~ 网络真的是很好的学习工具O(∩_∩)O哈哈哈~
当时很仔细的看了
1.阮一峰的Flex布局教程:语法篇和实例篇。(写于2015年7月)
语法篇网址http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html
实例篇网址http://www.ruanyifeng.com/blog/2015/07/flex-examples.html?bsh_bid=683103006
2.大漠根据Chris Coyier翻译的《老的flexbox和新的flexbox》和《使用CSS3 Flexbox》(写于2013年5月)
中文网址:http://www.w3cplus.com/css3/old-flexbox-and-new-flexbox.html
英文网址:http://css-tricks.com/old-flexbox-and-new-flexbox
以下是我的学习成果和案例分析。
如果你正在学习flex或者看了这篇文想要学习flex,那么我建议可以好好看看阮大神的文章。我的学习成果主要基于阮大神的文章,精简总结以便于个人查找。而案例分析,则是自己做的demo的实现,用于展示学习。
首先说明一下flex的功能。flex是Flexible Box的缩写,它是一种弹性布局的方式,更多的用在屏幕尺寸大小一大,网页需要适应不同尺寸的屏幕上。Flexbox可以让元素在容器(伸缩容器)中扩展和收缩,从而达到调整整个布局的响应效果。需要注意的一点是,flex布局后,子元素的float、clear、vertical-align属性都会失效。如图1 Flex布局容器展示图。

如图1 Flex布局容器展示图
介绍:采用Flex布局的元素,称为Flex容器(flex container),简称"容器"。它的所有子元素自动成为容器成员,称为Flex项目(flex item),简称"项目"。
容器默认存在两根轴:水平的主轴(main axis)和垂直的交叉轴(cross axis)。主轴的开始位置(与边框的交叉点)叫做main start,结束位置叫做main end;交叉轴的开始位置叫做cross start,结束位置叫做cross end。
项目默认沿主轴排列。单个项目占据的主轴空间叫做main size,占据的交叉轴空间叫做cross size。
flex属性
flex-direction 决定主轴方向
flex-wrap 默认情况下,项目都在一条线上,定义如何换行。
flex-flow 上述的简写,默认row nowrap。
justify-content 项目在主轴上的对齐方式
align-items 项目在交叉抽上如何对齐
align-content 多根轴线的对齐方式
① .box{flex-derection: row | row-reverse | column | column-reverse;}
row:主轴方向从左到右 。
row-reverse:主轴方向从右到左 。
column:交叉轴方向从上到下。
column-reverse:交叉轴方向从下到上。
案例:
② .box{flex-wrap: nowrap | wrap | wrap-reverse;}
nowrap: 默认不换行
wrap: 换行,第一排在上方
wrap-reverse:换行,第一排在下方
③ .box { flex-flow:<flex-direction>||<flex-wrap>; }
④ .box{justify-content: flex-start |flex-end | center | space-between | space-around;}
flex-start: 左对齐
flex-end:右对齐
center:居中
space-between:两端对齐,中间间隔
space-around:四周环绕,中间间隔大于item与边界间隔。
⑤ .box{align-items: flex-start | flex-end | center |baseline | stretch ;}
flex-start:交叉轴起点
flex-end :交叉轴终点
center:交叉轴中点
baseline :项目的第一行文字的基线对齐
stretch :默认,如果项目未设置高或auto,将占满整个容器。
⑥ .box{align-content: flex-start | flex-end | center | space-between |space-around | str }
flex-start:与交叉轴起点对齐
flex-end:与交叉轴终点对齐
center:与交叉轴中点对齐
space-between:两端对齐,中间间隔
space-around:四周环绕,中间间隔大于item与边界间隔。
stretch:默认,如果项目未设置高或auto,将占满整个容器。
未完待续。
flex学习小结的更多相关文章
- Python 学习小结
python 学习小结 python 简明教程 1.python 文件 #!/etc/bin/python #coding=utf-8 2.main()函数 if __name__ == '__mai ...
- react学习小结(生命周期- 实例化时期 - 存在期- 销毁时期)
react学习小结 本文是我学习react的阶段性小结,如果看官你是react资深玩家,那么还请就此打住移步他处,如果你想给一些建议和指导,那么还请轻拍~ 目前团队内对react的使用非常普遍,之 ...
- objective-c基础教程——学习小结
objective-c基础教程——学习小结 提纲: 简介 与C语言相比要注意的地方 objective-c高级特性 开发工具介绍(cocoa 工具包的功能,框架,源文件组织:XCode使用介绍) ...
- pthread多线程编程的学习小结
pthread多线程编程的学习小结 pthread 同步3种方法: 1 mutex 2 条件变量 3 读写锁:支持多个线程同时读,或者一个线程写 程序员必上的开发者服务平台 —— DevSt ...
- ExtJs学习笔记之学习小结LoginDemo
ExtJs学习小结LoginDemo 1.示例:(登录界面) <!DOCTYPE html> <html> <head> <meta charset=&quo ...
- 点滴的积累---J2SE学习小结
点滴的积累---J2SE学习小结 什么是J2SE J2SE就是Java2的标准版,主要用于桌面应用软件的编程:包括那些构成Java语言核心的类.比方:数据库连接.接口定义.输入/输出.网络编程. 学习 ...
- 【转】【Flex】FLEX 学习网站分享
[转:http://hi.baidu.com/tanghecaiyu/item/d662fbd7f5fbe02c38f6f764 ] FLEX 学习网站分享 http://blog.minidx.co ...
- (转) Parameter estimation for text analysis 暨LDA学习小结
Reading Note : Parameter estimation for text analysis 暨LDA学习小结 原文:http://www.xperseverance.net/blogs ...
- dubbo学习小结
dubbo学习小结 参考: https://blog.csdn.net/paul_wei2008/article/details/19355681 https://blog.csdn.net/liwe ...
随机推荐
- iframe关于滚动条的去除和保留
iframe嵌入页面后,我们有时需要调整滚动条,例如,去掉全部的滚动条,去掉右边的滚动条且保留底下的滚动条,去掉底下的滚动条且保留右边的滚动条.那么我们应该怎么做呢? 一:去掉全部的滚动条 第一个方法 ...
- IE7,6与Fireofx的CSS兼容性处理方法集结
CSS对浏览器的兼容性有时让人很头疼,尤其是对于IE6这个问题多多的浏览器版本,从网上收集了IE7,6与Fireofx的兼容性处理方法并整理了一下.对于web2.0的过度,请尽量用xhtml格式写代码 ...
- low security dvwa--SQL Injection(Blind)
1.输入单引号,结果如下: 2.输入永真式 ' and 1=1; -- 结果如下: 多次测试,如果输入的条件为假,就会返回1中的结果,为真则返回2中的结果,由此说明这属于SQL盲注. 3.猜解用户名长 ...
- iOS之在写一个iOS应用之前必须做的7件事(附相关资源)
本文由CocoaChina--不再犹豫(tao200610704@126.com)翻译 作者:@NIkant Vohra 原文:7 Things you must absolutely do befo ...
- java 中时间的比较 用compareTo方法
//compareTo 方法 是对象比较 大于 1 等于 返0 小于 返 -1 列 Date dat1=new Date(); Date dat2=new Date(); int va ...
- 11g新特性:Health Monitor Checks
一.什么是Health Monitor ChecksHealth Monitor Checks能够发现文件损坏,物理.逻辑块损坏,undo.redo损坏,数据字典损坏等等.Health Monitor ...
- 参加微软Ignite大会有感
很有幸作为MVP参加了本次微软中国的年度技术大会(Ignite).跳出技术领域,这次会议给我最大的感受是态度.这几年不论是开源现有技术,还是黑科技的发布,都给人感觉微软在逐渐变得cool,但是cool ...
- Spark SQL 之 Data Sources
#Spark SQL 之 Data Sources 转载请注明出处:http://www.cnblogs.com/BYRans/ 数据源(Data Source) Spark SQL的DataFram ...
- 4-iscsi
Iscsi 1. 创建lvm 2. 安装scsi服务端软件包 第一种(命令模式) 第二种(配置文件模式) 客户端 Node1 寻找scsi服务器上的储存设备 将scsi设备挂载 ...
- bug描述技巧
进入测试行业已经两年了,我从未认真的考虑过提交一个bug需要注意哪些问题,只是主观的认为我只需要描述清楚就OK了,但是我在工作中发现有个别的开发经常跑来告诉我"这个bug你是不是描述错了&q ...