使用CSS Flexbox创建等高定价表

发布时间:2020-05-27 00:42:37 作者:二哈少爷
阅读:508
前端开发者专用服务器,限时0元免费领! 查看>>

在我看来,定价表是最简洁有效的方式,可以快速捕捉并向潜在客户传达您的服务和优势一目了然。最近我正在为我的网站查看一个很好的定价表,并且几乎所有这些都意识到了问题 - 他们没有垂直响应。我的意思是,定价表中的每一列都有自己的高度,基于内部的内容量。我需要一个相等高度的定价表,其中所有列共享相同的高度而不依赖于表。

这是一个相等高度定价表的示例,我将向您展示如何使用CSS Flexbox进行创建。注意每列的高度与其对等点的高度相同,即使它们都有不同的内容行。此外,嵌入了号召性用语按钮的最后一个LI始终是底部对齐的:

简而言之,以下是创建等高定价表的两个关键CSS规则:

使用CSS Flexbox创建等高定价表

HTML标记

让我从HTML标记开始,我希望尽可能保持干净和精益。为此,我只为每个单独的定价表使用UL列表,所有这些都包含在DIV容器中:

1

2

3

4

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

<font style="vertical-align: inherit;"><font style="vertical-align: inherit;"><div class =“pricingdiv”></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    <ul class =“theplan”></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li class =“title”> <b>第二名</ b> <br /> Herman Miler </ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li> <b>体重:</ b> 55磅</ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li> <b>最大重量:</ b> 330磅</ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li> <a class="pricebutton" href="#"> <span class =“icon-tag”> </ span>结帐</a> </ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    </ UL></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    <ul class =“theplan”></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li class =“title”> <b>第一名</ b> <br /> Argomax主席</ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li> <b>材料:</ b>尼龙带透气玻璃纤维</ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li> <b>头枕:</ b>是</ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        “</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        “</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li> <a class="pricebutton" href="#"> <span class =“icon-tag”> </ span>结帐</a> </ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    </ UL></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    <ul class =“theplan”></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li class =“title”> <b>第三名</ b> <br /> Eurotech Mesh </ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li class =“ethighlight”> <b>尺寸:</ b> 24.8W x 47.3H </ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        “</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        <li> <a class="pricebutton" href=""> <span class =“icon-tag”> </ span>结帐</a> </ li></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    </ UL></font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

</ DIV></font></font>

如您所见,每个UL.theplan元素包含不同数量的LI条目。目标是使每个UL具有相同的高度,并且每个定价计划的最后一个LI条目在最底部排列。

我发现这是最简单的方法吗?使用CSS flexbox并将每个UL设置为 flex-direction:column使它们垂直扩展以匹配最长的flex儿童的高度。我将在下面详细解释。

CSS

这是等高定价表的CSS。我已经删除了不重要的位,因此您可以专注于重要的事情:

1

2

3

4

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

三十

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

<font style="vertical-align: inherit;"><font style="vertical-align: inherit;">.pricingdiv {</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    显示:flex;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    flex-wrap:wrap;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    辩解内容:中心;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

}</font></font><font></font>

<font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

.pricingdiv ul.theplan {</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    list-style:none;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    保证金:0;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    填充:0;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    显示:flex;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    弯曲方向:柱;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    宽度:260px; </font><font style="vertical-align: inherit;">/ *每张桌子的宽度* /</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    保证金权利:20px; </font><font style="vertical-align: inherit;">/ *表之间的间距* /</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    margin-bottom:1em;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    边框:1px实心灰色;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    过渡:全部.5s;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

}</font></font><font></font>

<font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

.pricingdiv ul.theplan:hover {/ *当鼠标悬停在定价表上时* /</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    变换:规模(1.05);</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    过渡:全部.5s;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    z-index:100;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    box-shadow:0 0 10px灰色;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

}</font></font><font></font>

<font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

.pricingdiv ul.theplan:last-of-type {/ *删除最后一个表中的右边距* /</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    margin-right:0;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

}</font></font><font></font>

<font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

/ *每个定价中的最后一个LI * *</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

.pricingdiv ul.theplan li:last-of-type {</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    text-align:center;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    margin-top:auto; </font><font style="vertical-align: inherit;">/ *将最后一个LI(价格botton li)对齐到UL *的最底部</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

}  </font></font><font></font>

<font></font>

<font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

@media only screen and(max-width:600px){</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    .pricingdiv ul.theplan {</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        border-radius:0;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        宽度:100%;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        margin-right:0;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    }</font></font><font></font>

<font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    .pricingdiv ul.theplan:hover {</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        变换:无;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        box-shadow:none;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    }</font></font><font></font>

    <font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    .pricingdiv a.pricebutton {</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

        显示:块;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    }</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

}</font></font>

我首先将父DIV容器设置为display:flex,并允许flex子项包装并使用flex-wrap: wrap 和水平居中justify-content: center。所有儿童UL元素都被认为是儿童。

对于每个由UL元素组成的定价表,我都设置了 flex-direction:column。默认情况下,flex子项在水平轴上播放。通过设置direction:column,我强制flex儿童的所有默认行为发生在垂直平面上,包括默认情况下金色奖励等于高度flex儿童

底部对齐每个UL定价表中的最后一个LI

所以DIV中的所有单独定价表现在都是相同的高度,但仍然需要一个重要的改进来使一切看起来都很精致。我希望调用操作按钮(包含在每个UL的最后一个LI中)与表格的最底部对齐。

要做到这一点涉及两个步骤。首先,我将每个UL定价表设置为一个flexbox容器本身(display: flex)。完成后,我可以使用该margin属性将特定子元素与其对等元素对齐,例如左对齐或右对齐以用于水平弹性子元素,或者在此情况下为垂直弹性子元素,顶部或底部。

为了使最后一个LI元素在底部对齐,要添加的神奇成分margin-top: auto在这些元素中:

1

2

3

4

<font style="vertical-align: inherit;"><font style="vertical-align: inherit;">.pricingdiv ul.theplan li:last-of-type {</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    text-align:center;</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

    margin-top:auto; </font><font style="vertical-align: inherit;">/ *将最后一个LI(价格botton li)对齐到UL *的最底部</font></font><font></font><font style="vertical-align: inherit;"><font style="vertical-align: inherit;">

}</font></font>

结论

正如您所看到的,CSS Flexbox使创建高度相同,响应迅速,甚至在页面中心的元素变得轻而易举。它帮助我解决了我所见过的许多CSS定价表中的大多数问题。我希望你能找到我有所帮助的技巧。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读:
  1. CSS3弹性模型
  2. CSS中flexbox的作用是什么

开发者交流群:

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

使用 css flexbox

上一篇:分布式计算框架MapReduce

下一篇:Oracle里另外一些典型的执行计划

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》
开发者交流群×