资讯专栏INFORMATION COLUMN

Flex布局在小程序的使用

FingerLiu / 808人阅读

摘要:所以为了在小程序开发中更方便地布局,有必要来详细了解下布局在小程序的使用。本文将针对布局的各个属性进行介绍,并直接使用来编写例子,运行环境是小程序的开发者工具。在容器使用会导致布局失效。

一篇旧文,上手小程序时做的一些探索

Flex布局是一种十分灵活方便的布局方式,目前主流的现代浏览器基本都实现了对Flex布局的完全支持。而在微信小程序中,IOS端使用的渲染引擎WKWebView和安卓端使用的X5 ,也都实现了对Flex的支持。所以为了在小程序开发中更方便地布局,有必要来详细了解下Flex布局在小程序的使用。本文将针对Flex布局的各个属性进行介绍,并直接使用wxss来编写例子,运行环境是小程序的开发者工具。

Flex布局的基本概念

Flex布局直接应用于一个Flex容器,布局的对象是容器中的各个项目元素(“item”)。项目元素布局的核心概念在于两条轴:主轴和交叉轴,通过控制项目元素在主轴、交叉轴上的排列方式进行布局,参见下图:

这里要注意两条轴的方向不是固定的(可以通过flex-direction来控制);此外一个Flex容器里可以再包含Flex容器,也就是能拥有多根主轴和交叉轴。

Flex容器属性

容器属性有6个:

flex-direction

flex-wrap

flex-flow

justify-content

align-items

align-content

flex-direction

设定主轴方向:

row →(默认)

row-reverse ←

column ↓

column-reverse↑

flex-wrap

规定如果容器在主轴方向无法容下所有项目,主轴上的项目如何换行(flex-direction为column和column-reverse时,就是“换列”了):

nowrap(默认),即不作换行,各个项目相接触时会挤压使宽度变小

wrap:换行,正常从上到下

wrap-reverse:换行,只是各行在交叉轴上的排列方向和wrap时相反

flex-flow

flex-direction和flex-wrap的简写,默认值为“row wrap”。

justify-content

所有项目在主轴上对齐方式:

none(默认)

center:在主轴上居中

flex-start:主轴起点对齐

fex-end:主轴终点对齐

space-between:两端对齐,项目间间隔相等

space-around:各项目两侧间隔相等

align-items

所有项目在交叉轴上对齐方式:

stretch(默认),即项目取auto大小时拉伸以占满容器的在交叉轴方向上的大小

center:在交叉轴上居中

flex-start:交叉轴起点对齐

flex-end: 交叉轴终点对齐

baseline:各项目第一行文字的基线对齐

align-content

定义了多根主轴的对齐方式,如果项目只有一根主轴则不起作用,多根主轴一般会在主轴上折行时出现:

stretch(默认),即auto大小时主轴线上的项目会拉伸来占满整个交叉轴。

center:在交叉轴上居中

flex-start:交叉轴起点对齐

flex-end: 交叉轴终点对齐

space-between:两端对齐,项目间间隔相等

space-around:各项目两侧间隔相等

Flex项目属性

项目属性有6个:

order

flex-basis

flex-grow

flex-shrink

flex

align-self

order

定义项目排列序号;默认为0,可为负:

flex-basis

在Flex项目自适应放大缩小之前,项目占据的主轴空间的基值。

默认值为auto,即项目的本来大小:

flex-grow

注意该属性指定的是项目对剩余空间的瓜分比例,这里有两个关键点:

容器在主轴上要有剩余空间

该属性是对剩余空间的瓜分,也即项目的最终大小是各项目的flex-basis大小、再加上瓜分得到的大小

默认为0,即如果存在剩余空间也不放大(grow),不可为负:

flex-shrink:

空间不足时项目对缩小份额的瓜分比例,还是有两个关键点:

容器在主轴上空间不足以放下所有的项目

空间不足可以让项目缩小,而该属性就是对缩小份额的瓜分,也即项目的最终大小是各项目的flex-basis大小、再减去瓜分得到的缩小份额

默认为1,即如果空间不足项目将缩小,不可负:

flex

flex-grow, flex-shrink 和 flex-basis的简写。

默认值为“0 1 auto”,还有两个值auto即“1 1 auto”、none即“0 0 auto”。

align-self

让一个项目有与其他项目不同的交叉轴对齐方式,主要用来覆盖align-items属性。

默认值是auto,即继承父元素的align-items属性,若无父元素则等同于stretch;其他值效果和align-items一样。

总结

Flex布局也叫弹性布局,个人理解所谓“弹性”主要体现在Flex项目的自伸缩上。主轴上的自伸缩主要通过flex-grow、flex-shrink来控制,交叉轴上的自伸缩则体现在align-*属性的默认值stretch上。

一些注意点

一些属性会在对Flex项目上无效:column-*属性、float 和 clear、vertical-align 。

在Flex容器使用 float 会导致Flex布局失效。

参考

Flex 布局教程

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/112749.html

相关文章

  • CSS 常用布局在小程序应用

    摘要:常用布局在小程序中的应用所有布局的根本都是个基本概念定位浮动外边距操纵我们其他的布局实现方式,都是基于正常的文档流来进行的。具体实现,可以使用微信小程序的单位,以及使用定位浮动布局来实现。 CSS 常用布局在小程序中的应用 所有css布局的根本都是3个基本概念:定位、浮动、外边距操纵 我们其他的布局实现方式,都是基于正常的文档流来进行的。所以我们先来看看什么是正常的文档流。 正常文...

    garfileo 评论0 收藏0
  • CSS 常用布局在小程序应用

    摘要:常用布局在小程序中的应用所有布局的根本都是个基本概念定位浮动外边距操纵我们其他的布局实现方式,都是基于正常的文档流来进行的。具体实现,可以使用微信小程序的单位,以及使用定位浮动布局来实现。 CSS 常用布局在小程序中的应用 所有css布局的根本都是3个基本概念:定位、浮动、外边距操纵 我们其他的布局实现方式,都是基于正常的文档流来进行的。所以我们先来看看什么是正常的文档流。 正常文...

    CoderDock 评论0 收藏0
  • 写给 Android 开发程序布局指南,Flex 布局

    摘要:不过在小程序中,这就不是我们需要考虑的了,微信已经帮我们处理好了。而在新手阶段,暂时只需要关注两个参数指定一个块级布局,它其内的元素,总是起一个新行来显示,而微信小程序的很多视图容器组件,默认的就是,例如等。 showImg(https://segmentfault.com/img/remote/1460000015285633?w=750&h=562); 一、序 Hi,大家好,我是承...

    Salamander 评论0 收藏0
  • 微信小程序

    摘要:小程序抛弃了传统的直接操作的开发方法采用了的开发思路实现动态解析。借鉴之前炒的很火的框架思路实现了诸如单向数据绑定可移植在过程中真的是只需要关心逻辑的实现数据的排序避免反复的查找丶操作。 写一个微信小程序系列的开发关键点 小程序基本架构 showImg(http://upload-images.jianshu.io/upload_images/4384845-cea5b04cbae...

    SunZhaopeng 评论0 收藏0

发表评论

0条评论

FingerLiu

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<