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

css3 flex属性flex-grow、flex-shrink、flex-basis学习笔记

作者:qq_35679291的博客 字体:[增加 减小] 来源:互联网 时间:2017-08-21

本文主要包含flex等相关知识,qq_35679291的博客希望在学习及工作中可以帮助到您

最近在研究css3的flex。遇到的flex:1;这一块,很是很纠结,flex-grow、flex-shrink、flex-basis始终搞不清,最经搜集了大量的介绍,应该能算是明白了。 网上大部分解释是 flex-grow 是扩展比率 flex-shrink 是收缩比率 flex-basis 伸缩基准值 假设flex盒子父级宽度固定为800px; Flex-grow、Flex-shrink、Flex-basis 是Flex属性的分写模式; 如 .box { flex: 4 3 100px; } 等于 .box { flex-grow: 4; flex-shrink: 3; flex-basis: 100px; } 看以下例子


.flex-parent {
width: 800px;
}

第一种情况
flex-parent 是父级,而且他的宽度是固定为800px,不会改变;
开始设置子级flex属性;

.flex-son:nth-child(1){
flex: 3 1 200px;
}
.flex-son:nth-child(2){
flex: 2 2 300px;
}
.flex-son:nth-child(3){
flex: 1 3 500px;
}

flex-basis总和加起来为1000px; 那么 1000px > 800px (父级的宽度);子元素势必要压缩;溢出了200px;

son1 = (flex-shrink) * flex-basis;
son2 = (flex-shrink) * flex-basis;
…..
sonN = (flex-shrink) * flex-basis;

如果flex-basis的总和加起来大于父级宽度,子级被压缩,最后的选择是flex-shrink来进行压缩计算
加权值 = son1 + son2 + …. + sonN;

那么压缩后的计算公式就是

压缩后宽度 w = (子元素flex-basis值 * (flex-shrink)/加权值) * 溢出值

所以最后的加权值是
1*200 + 2*300 + 3*500 = 2300px

son1的扩展量:(200 * 1/ 2300) * 200,即约等于17px;
son2的扩展量:(300 * 2/ 2300) * 200,即约等于52px;
son3的扩展量:(500 * 3/ 2300) * 200,即约等于130px;

最后son1、son2、son3,的实际宽度为:
200 – 16 = 184px;
300 – 52 = 248px;
500 – 230 = 370px;

第二种情况

上面的例子已经说明,继续看第二个例子,同样上面的例子,我们改下父级宽度为1200px;
flex-basis的总和为 1000px,小于父级宽度,将有200px的剩余宽度;
既然有剩余,我们就不要加权计算,剩余的宽度将根据flex-grow,值得总和进行百分比,那么200px就会根据份数比来分配剩余的空间;

剩余后宽度 w = (子元素flex-grow值 /所有子元素flex-grow的总和) * 剩余值

总分数为 total = 1 + 2 + 3;

son1的扩展量:(3/total) * 200,即约等于100px;
son2的扩展量:(2/total) * 200,即约等于67px;
son3的扩展量:(1/total) * 200,即约等于33px;

最后son1、son2、son3,的实际宽度为:
200 + 100 = 300px;
300 + 67 = 367px;
500 + 33 = 533px;

总结

所以以上两种情况下,第二种flex-basis和flex-shrink是不列入计算公式的;第一种flex-grow是不列入计算公式的

ok,上面的两种情况总结完毕,但是很多时候我们的父级是不固定的,那么怎么办,其实很简单了,对照上面的公式,前提是已经设置了flex-basis值得元素,如果宽度的随机值小于flex-basis的时候就按第一种计算,反之第二种;明白了吧。

但是在实际中,我们有些子元素不想进行比例分配,永远是固定的,那么flex就必须设置为none;
否则设置的宽度(width)将无效;

flex: 1, 则其计算值为 flex: 1 1 0%;
flex: auto, 则其计算值为 flex: 1 1 auto;
flex: none, 则其计算值为 flex: 0 0 auto;

根据上面的公式
flex:1的时候第一种方式其实是无效的,因为加权值是0,所以只能是第二种方式计算;
flex:none的时候,两种都失效,自己元素不参与父级剩余还是溢出的分配,flex:none的应用场景还是很多的;

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

相关文章

  • 2017-06-02CSS3中的@keyframes关键帧动画的选择器绑定
  • 2017-06-02使用CSS实现阅读进度条
  • 2017-06-02CSS3+DIV实现漂亮的动画彩色标签
  • 2017-06-02CSS3教程(10):CSS3 HSL声明设置颜色
  • 2017-06-02css3的transition效果和transfor效果示例介绍
  • 2017-06-02css3隔行变换色实现示例
  • 2017-06-02你应该知道的30个css选择器
  • 2017-06-02总结30个CSS3选择器
  • 2017-06-02css3的transform造成z-index无效解决方案
  • 2017-06-0225个CSS3动画按钮和菜单教程分享

文章分类

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

最近更新的内容

    • HTML5+CSS3 诱人的实例:3D立方体旋转动画实例
    • 实例讲解CSS3中Transform的perspective属性的用法
    • 超酷炫 CSS3垂直手风琴菜单
    • 10 套华丽的CSS3 按钮小结
    • css3+伪元素实现鼠标移入时下划线向两边展开的效果
    • 基于CSS3的CSS 多栏(Multi-column)实现瀑布流源码分享
    • CSS3 Media Queries详细介绍和使用实例
    • css实例教程 一款纯css3实现的超炫动画背画特效
    • css3实现3D色子翻转特效
    • 使用css3实现的windows8开机加载动画

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

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