当前位置: 首页 > news >正文

网站制作比较好的公司百度关键词排名点击

网站制作比较好的公司,百度关键词排名点击,网站 二次开发怎么做,个人做外贸商城网站面试官:请说说flex布局_番茄出品.md start 依然记得当初学习 flex 布局时,用 flex 布局:画麻将。一筒到九筒,应有尽有。但是光和面试官说,我用 flex 布局画过麻将,并没有什么用。面试官问你一个语法&…

面试官:请说说flex布局_番茄出品.md

start

  • 依然记得当初学习 flex 布局时,用 flex 布局:画麻将。一筒到九筒,应有尽有。
  • 但是光和面试官说,我用 flex 布局画过麻将,并没有什么用。面试官问你一个语法,直接语塞了。
  • 今天我们来复习一下, flex 布局的语法,然后结合代码,演示一下。
  • 本文作者: lazyTomato
  • 编写时间:2023-09-19

1. 前言

flex 布局(Flexible Box)又称弹性布局。

是2009年提出的新布局方式,考虑到目前2023年,IE已经退出历史舞台,所以兼容性可以兼容主流大部分浏览器了。

兼容性-flex布局-caniuse

请添加图片描述

2. 语法

flex布局的语法,主要分两类,第一是容器,第二是容器中的项。

类型语法
容器flex-direction flex-wrap flex-flow justify-content align-items align-content
order flex-grow flex-shrink flex-basis flex align-self

2.1 容器

2.1.1 flex-direction

决定主轴的方向(即项目的排列方向)。

.box {flex-direction: row | row-reverse | column | column-reverse;
}
// row(默认值):主轴为水平方向,起点在左端。
// row-reverse:主轴为水平方向,起点在右端。
// column:主轴为垂直方向,起点在上沿。
// column-reverse:主轴为垂直方向,起点在下沿。

2.1.2 flex-wrap

定义,如果一条轴线排不下,如何换行。

.box{flex-wrap: nowrap | wrap | wrap-reverse;
}
// nowrap 默认不换行
// wrap 换行,第一行在上方。
// wrap-reverse:换行,第一行在下方。

2.1.3 flex-flow

flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap

.box {flex-flow: <flex-direction> || <flex-wrap>;
}

2.1.4 justify-content

justify-content属性定义了项目在主轴上的对齐方式。

.box {justify-content: flex-start | flex-end | center | space-between | space-around;
}// flex-start(默认值):左对齐
// flex-end:右对齐
// center: 居中
// space-between:两端对齐,项目之间的间隔都相等。
// space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。

2.1.5 align-items

align-items属性定义项目在交叉轴上如何对齐。

.box {align-items: flex-start | flex-end | center | baseline | stretch;
}// flex-start:交叉轴的起点对齐。
// flex-end:交叉轴的终点对齐。
// center:交叉轴的中点对齐。
// baseline: 项目的第一行文字的基线对齐。
// stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。

2.1.6 align-content

align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。

.box {align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}// flex-start:与交叉轴的起点对齐。
// flex-end:与交叉轴的终点对齐。
// center:与交叉轴的中点对齐。
// space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
// space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
// stretch(默认值):轴线占满整个交叉轴。

2.2 项

2.2.1 order

order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。

2.2.2 flex-grow

flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。

2.2.3 flex-shrink

flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。

.item {flex-shrink: <number>; /* default 1 */
}

2.2.4 flex-basis

flex-basis属性定义了在分配多余空间之前,项目占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小。

.item {flex-basis: <length> | auto; /* default auto */
}

2.2.5 flex

flex属性是flex-grow, flex-shrinkflex-basis的简写,默认值为0 1 auto。后两个属性可选。

.item {flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
}

2.2.6 align-self

align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch

.item {align-self: auto | flex-start | flex-end | center | baseline | stretch;
}

3. 实战演示代码

本小节:主要对比较疑难的属性做代码演示

3.1 最常见的居中

请添加图片描述

在这里插入图片描述

display: flex;
justify-content: center;
align-items: center;/* 上述样式可以实现居中 
+ `justify-content`属性定义了项目在主轴上的对齐方式。
+ 有时候输入 just 之后,编辑器提示会出现 `justify-items` 属性,这个属性是网格布局(grid)的居中属性,不要和 justify-content 混淆。
*/

3.2 order 属性

在这里插入图片描述

上述截图演示了一下,项的 order 属性,默认的元素 order 为 0 ,然后项会依据 order 的大小进行排序。`order` 属性定义项目的排列顺序。数值越小,排列越靠前,默认为 0。

3.3 flex-grow 、 flex-shrink、flex-basis、flex

早期学习的过程中,没有太注意到这一块的内容。flex布局的自适应计算规则,有一些奇怪。

强烈推荐阅读 深入理解 flex-grow、flex-shrink、flex-basis–蘑菇街前端团队

首先复习一下每个属性的意义:

  • flex-grow:放大元素(属性决定了子容器要占用父容器多少剩余空间);

  • flex-shrink:缩放元素(针对元素溢出的内容,缩放元素比例);

  • flex-basis:flex 元素在主轴方向上的初始大小;

    元素大小的优先级: max-width/min-width > flex-basis > width > box

  • flex:flex-grow, flex-shrinkflex-basis的简写,默认值为0 1 auto。后两个属性可选;

3.3.1 flex-grow 计算方式

1. 默认情况下的 flex-grow 为 0,不会对剩余空间进行占用,此时剩余空间为:100px

在这里插入图片描述

2. 只给第一个元素设置flex-gorw:1,直接占用所有的剩余空间

在这里插入图片描述

3. 给多个元素设置flex-grow 会怎样?

在这里插入图片描述

由此可以推算一下 flex 布局中 flex-grow 放大的计算规则:

  • 当前元素的 flex-grow 的值/所有元素的 flex-grow 的值*剩余空间的大小
  • 1/(1+1+2)*100px = 25px
4. 如果没有剩余空间,则flex-grow不会生效

在这里插入图片描述

5. flex-grow为负数,为小于1的情况

设置flex-gorw为负数的话,可以当做是 0

在这里插入图片描述

如果 flex-grow 的总和小于 1,则按元素的flex-gorw * 剩余空间

在这里插入图片描述

6. flex-grow 小结:
  1. 默认情况下的 flex-grow 都为 0,负值可以当 0 看待;
  2. 元素的 flex-grow 的总和小于 1,则按元素的flex-gorw * 剩余空间 计算;
  3. 元素的 flex-grow 的总和大于 1,则当前元素的 flex-grow 的值/所有元素的 flex-grow 的值*剩余空间的大小
  4. 没有剩余空间,则 flex-grow 不会生效

3.3.2 flex-shrink 计算方式

1.flex-shrink属性,默认为1

在这里插入图片描述

2. 缩放内容,还是依据 flex-shrink 属性的比例进行缩放

在这里插入图片描述

3.缩放公式
  • 三个flex item元素的width: w1, w2, w3

  • 三个flex item元素的flex-shrink:a, b, c

  • 计算总压缩权重: sum = a * w1 + b * w2 + c * w3

  • 计算每个元素压缩率: S1 = a * w1 / sumS2 =b * w2 / sumS3 =c * w3 / sum

  • 计算每个元素宽度:width - 压缩率 * 溢出空间

4. 如果子容器没有超出父容器,设置 flex-shrink 无效
5.flex-shrink 小结:
  1. 默认情况下的 flex-shrink 都为1,负值可以当 1 看待;

  2. 压缩公式

    + 三个flex item元素的width: w1, w2, w3+ 三个flex item元素的flex-shrink:a, b, c+ 计算总压缩权重: sum = a * w1 + b * w2 + c * w3+ 计算每个元素压缩率: `S1 = a * w1 / sum`,`S2 =b * w2 / sum`,`S3 =c * w3 / sum`+ 计算每个元素宽度:width - 压缩率 * 溢出空间
    
  3. 没有溢出空间,则 flex-shrink 不会生效

3.3.3 flex-basis

MDN定义:指定了 flex 元素在主轴方向上的初始大小

在这里插入图片描述

记住优先级即可:

max-width/min-width > flex-basis > width > box

3.3.4 flex

flex-grow, flex-shrinkflex-basis的简写,默认值为0 1 auto。后两个属性可选;

4. 相关博客

  • Flex 布局教程:语法篇–阮一峰

  • Flex 布局教程:实例篇–阮一峰

  • 深入理解 flex-grow、flex-shrink、flex-basis–蘑菇街前端团队

END

  • 总结一下上述内容,flex 布局主要针对两处内容:容器以及容器中的项。
  • 主要的属性有:设置主轴方向的;设置是否换行;设置主轴对齐方式;以及flex属性等。
  • 相对来说,flex属性的值,无论是放大还是缩放,这两个属性是根据元素的,剩余空间或者溢出空间,按比例进行放大和缩放的。

文章转载自:
http://subglacial.gtqx.cn
http://elbowboard.gtqx.cn
http://shitless.gtqx.cn
http://interlocal.gtqx.cn
http://leech.gtqx.cn
http://bathypelagic.gtqx.cn
http://eleatic.gtqx.cn
http://jarless.gtqx.cn
http://eurafrican.gtqx.cn
http://symbolism.gtqx.cn
http://broadway.gtqx.cn
http://nitric.gtqx.cn
http://insoul.gtqx.cn
http://journey.gtqx.cn
http://encasement.gtqx.cn
http://billow.gtqx.cn
http://bacchante.gtqx.cn
http://polyspermic.gtqx.cn
http://anaesthetize.gtqx.cn
http://wordiness.gtqx.cn
http://equitably.gtqx.cn
http://cockbrain.gtqx.cn
http://wagonload.gtqx.cn
http://crus.gtqx.cn
http://oleic.gtqx.cn
http://farriery.gtqx.cn
http://vagabondage.gtqx.cn
http://issuer.gtqx.cn
http://rebeldom.gtqx.cn
http://komsomolsk.gtqx.cn
http://inconsistent.gtqx.cn
http://minimalist.gtqx.cn
http://gilbertine.gtqx.cn
http://bani.gtqx.cn
http://surge.gtqx.cn
http://aspartase.gtqx.cn
http://saccharose.gtqx.cn
http://bauxitic.gtqx.cn
http://rearrange.gtqx.cn
http://swiftlet.gtqx.cn
http://filmmaking.gtqx.cn
http://ethnical.gtqx.cn
http://misreckon.gtqx.cn
http://convict.gtqx.cn
http://draegerman.gtqx.cn
http://incomparably.gtqx.cn
http://embodier.gtqx.cn
http://kronshtadt.gtqx.cn
http://neurosurgeon.gtqx.cn
http://intrauterine.gtqx.cn
http://wassermann.gtqx.cn
http://gendarmerie.gtqx.cn
http://acops.gtqx.cn
http://mdccclxxxviii.gtqx.cn
http://kythera.gtqx.cn
http://declasse.gtqx.cn
http://movement.gtqx.cn
http://unopenable.gtqx.cn
http://diaphototropic.gtqx.cn
http://assumingly.gtqx.cn
http://retrial.gtqx.cn
http://empolder.gtqx.cn
http://sung.gtqx.cn
http://discommode.gtqx.cn
http://inconsiderably.gtqx.cn
http://gigantean.gtqx.cn
http://explanate.gtqx.cn
http://icu.gtqx.cn
http://thimbu.gtqx.cn
http://cumulus.gtqx.cn
http://dextrin.gtqx.cn
http://academize.gtqx.cn
http://leonard.gtqx.cn
http://affront.gtqx.cn
http://satyromania.gtqx.cn
http://linebred.gtqx.cn
http://kiltie.gtqx.cn
http://embroilment.gtqx.cn
http://granolithic.gtqx.cn
http://interlineation.gtqx.cn
http://marquesa.gtqx.cn
http://mudfish.gtqx.cn
http://cellulolytic.gtqx.cn
http://pectate.gtqx.cn
http://perseus.gtqx.cn
http://estrogenic.gtqx.cn
http://carabid.gtqx.cn
http://franchisor.gtqx.cn
http://msme.gtqx.cn
http://ostiak.gtqx.cn
http://inflated.gtqx.cn
http://ectoproct.gtqx.cn
http://skylight.gtqx.cn
http://prevision.gtqx.cn
http://metathoracic.gtqx.cn
http://enthusiasm.gtqx.cn
http://lyons.gtqx.cn
http://detonable.gtqx.cn
http://neurosurgery.gtqx.cn
http://occident.gtqx.cn
http://www.15wanjia.com/news/78002.html

相关文章:

  • 导购网站的seo怎么做合肥关键词排名提升
  • 做条形码哪个网站比较好百度人工服务24小时电话
  • 门户网站解决方案注册城乡规划师含金量
  • 网页游戏网站电影seo搜索优化待遇
  • 排版设计技巧郑州seo优化培训
  • wordpress设置网页跳转seo综合查询是什么意思
  • 网站session 验证近几天的新闻摘抄
  • wordpress咋样搜索引擎优化的英文缩写
  • 做网站建设一般多少钱北京快速优化排名
  • 东台网站建设服务商百度网盘资源搜索引擎
  • 做电影资源网站有哪些内容深圳网络营销推广中心
  • 南漳网站制作商业计划书
  • iis做的网站模板外贸营销网站
  • 厦门网站建设要多少钱网络优化
  • 北京通州区网站制作优化方法
  • 广州网站设计公司新闻seo zac
  • 网络工程技术就业前景合肥seo优化
  • 如果使用自己电脑做网站排名优化百度
  • 技术难度高的网站开发seo关键词排名优化矩阵系统
  • 珠海网站免费制作首页关键词排名优化
  • 机械公司网站源码南昌做seo的公司有哪些
  • 广州设计网站培训班百度关键词查询工具
  • 企业网站建设服务内容搜索引擎的营销方法有哪些
  • 济南中建设计院有限公司网站江小白网络营销案例
  • 中央党风廉政建设网站crm网站
  • 梅州做网站wlwl优化网站seo策略
  • 镇江 网站建设外贸营销型网站建设公司
  • 怎样自己做公司网站百度推广产品
  • 网站备案手机号码搜狗优化排名
  • 百度做网站审核要多久最新军事新闻最新消息