Flex布局又称弹性布局,在小程序开发中比较适用。因此将Flex布局相关属性整理如下,搞清楚了这个布局,小程序开发的页面布局就不在话下了。布局的传统解决方案,基于盒状模型,依赖 display属性 position属性 float属性。它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现。
Flex布局默认是通过主轴和侧轴来排列元素的,如果没有设置主轴和侧轴的方向,主轴默认是水平方向,侧轴默认是竖直方向。因此,如果一个div使用了Flex布局且没有指定主轴和侧轴的方向,那么其中的文字就会默认排列在侧轴(竖直方向)上。
要改变这种排列方式,可以使用Flex布局的justify-content和align-items属性来设置主轴和侧轴的方向。
我们这里分为两种形式,一种是定元素宽高的情况下,另一种是不定元素宽高的情况下。
定元素宽高的情况下
a.绝对定位 负margin
利用绝对定位absolute和margin完成元素居中,具体例子如下:
给父元素添加相对定位,子元素添加绝对定位,利用margin负子元素宽高的一半,实现元素的居中,这种方法不常用,
优点:好理解,兼容性好
缺点:必需给定子元素的宽高
b.绝对定位 margin:auto
利用absolute绝对定位和margin:auto自动居中方法完成元素的居中,例子如下:
与上例子一样给父元素加相对定位,子元素添加绝对定位,在设置元素的左、右、上、下位置为零,再利用自动居中对齐的方法margin:auto,完成元素的垂直水平居中,这种方法常用
优点:简单易懂,兼容性好
缺点:代码量大,占内存
c.table-cell
利用css的table属性,完成元素的垂直居中,margin完成元素的水平居中,例子如下
设置父元素的元素类型为table-cell类型,设置表格的垂直对齐方式为居中,再给子元素添加margin:0 auto 完成元素的垂直水平居中,这种方法不常用,
优点:兼容性好
缺点:出来的太早,现在都不流行用了
d.translate
利用2d位移来完成元素的居中,例子如下:
只需操作子元素,给子元素添加transform属性,利用2d位移translate,分别向左向右移动父元素宽高度减自身宽高度的一半,完成元素的垂直水平对齐,这种方法不常用,
优点:代码简单
缺点:我们必须给定子元素的宽和高,否则无法完成元素居中
不定元素宽高的情况下
line-heght
给元素设置line-heght,也就是行高,完成元素的居中,具体例子如下:
我们给子元素设置行高,完成元素的垂直居中,再然后利用文本水平对齐方式text-align方法,完成水平居中,这中方法是最简单的,也是我们经常用的
优点:写起来简单,兼容性好
缺点:只适合单行文本的居中,多行文本不支持
b.绝对定位加translate
之前我们说过一个利用translate完成元素垂直水平的,这里就是在那种方法上的进一步改进,也就是可以,不用设置宽高,也能实现元素的垂直水平居中,用translate加绝对定位完成元素的居中,例子如下:
在这里,还有不同就是,我们translate里面可以直接用百分比完成位移,从而实现元素的垂直水平居中,这种方法常用(但是我不常用)
优点:代码简单,兼容性好
缺点:无
c.flex
flex形成弹性盒,我们利用弹性盒可以做很多事情,其中最主要的还是布局,当然这里我们就不详细说了,我们来谈谈如何使一个元素垂直水平居中,例子如下:
我们让父元素形成弹性盒子,再然后设置主轴对齐方式为居中对齐,侧轴对齐方式为居中对齐从而完成元素的垂直水平居中,这种方法经常用,
优点:代码简单易懂
缺点:PC端兼容性不好
d.flex margin:auto
这种方法与上面那种不同的是,这里没用到弹性盒子里面的属性,而是用margin直接完成元素的居中对齐,例子如下:
让父元素形成弹性盒子,再然后给子元素添加margin:auto,完成元素的垂直水平居中,这种方法也常用,
垂直定位是指在网页设计中,对网页元素进行上下方向上的布局和定位操作。通常,我们使用HTML和CSS来实现垂直定位。在网页设计中,垂直定位非常重要,因为它可以让我们有效地控制页面的结构和布局,从而让页面更加美观和易于使用。
在实现垂直定位时,我们可以使用一些常见的技术,例如使用CSS的定位属性、使用flex布局、使用表格布局等等。
此外,我们还可以通过设置元素的高度和垂直对齐方式来实现垂直定位。不管使用什么方法,垂直定位都是网页设计中非常重要的一部分,可以帮助我们实现美观、易于使用的网页设计。
有float、clear和vertical-align属性,因为父元素flex布局,子元素的这些属性不生效。
正加财富网内容推荐 | ||
OK交易所下载 | USDT钱包下载 | 比特币平台下载 |
新手交易教程 | 平台提币指南 | 挖矿方法讲解 |