码迷,mamicode.com
首页 > Web开发 > 详细

html多个水平并列组件自适应等高的做法

时间:2015-10-17 17:23:23      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:

做一个div盒子,设置over-flow:hidden,设置高度为auto。然后再盒子里排列若干inline-block,inline元素。

自适应的话常用做法是用line-height,font-size加上垂直padding设置高度。font-size可以用pt或是em设置。这样在不同分辨率下能显示不同的像素值,并且撑开父盒子的高度。

以一个元素为inline-block,设置垂直高度撑开父盒子,其他元素设置成inline,设置垂直padding,尽可能设置较大值,远大于父盒子的高度, 多出的部分会因为overflow的缘故被遮挡,看起来就和inline-block元素一样高了。

这里应用到的基本原理:

  • display:block
    1. block元素会独占一行,多个block元素会各自新起一行。默认情况下,block元素宽度自动填满其父元素宽度。
    2. block元素可以设置width,height属性。块级元素即使设置了宽度,仍然是独占一行。
    3. block元素可以设置margin和padding属性。
  • display:inline
    1. inline元素不会独占一行,多个相邻的行内元素会排列在同一行里,直到一行排列不下,才会新换一行,其宽度随元素的内容而变化。
    2. inline元素设置width,height属性无效。
    3. inline元素的margin和padding属性,水平方向的padding-left, padding-right, margin-left, margin-right都产生边距效果;但竖直方向的padding-top, padding-bottom, margin-top, margin-bottom不会产生边距效果。
  • display:inline-block
    1. 简单来说就是将对象呈现为inline对象,但是对象的内容作为block对象呈现。之后的内联对象会被排列在同一行内。比如我们可以给一个link(a元素)inline-block属性值,使其既具有block的宽度高度特性又具有inline的同行特性。

 这里之所以这样处理的原因是元素的内容和字体大小不同,可能撑开的高度不一样,并且不容易做统一设置。

html多个水平并列组件自适应等高的做法

标签:

原文地址:http://www.cnblogs.com/baozhu/p/4887666.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!