css:连续几个DIV都是position:relative;top:20px,最后一个DIV的最后一行显示不出来,正常么?怎么解决?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了css:连续几个DIV都是position:relative;top:20px,最后一个DIV的最后一行显示不出来,正常么?怎么解决?相关的知识,希望对你有一定的参考价值。

又试了一下,发现是浏览器的问题,IE6里有这样的问题,但在chrome和firefox里都正常的。不过IE6里我也是要用的。1、2楼的方法我试过了,没生效。

可能是我copy来的例子为解决IE6的代码出的问题:
_position: absolute; /* position fixed for IE6 */
_top: expression(documentElement.scrollTop + "px");
但,在IE6中,顶部这段代码是可以工作的,但底部就产生了丢失行的问题。

你在这些position:relative;top:20px的DIV前是不是有一个fix 或 absolute 的div?如果有的话,你在那个DIV外面再套上一个top:20px的div,这样后续的div就不用 position:relative;top:20px 啦!最后那行也就不会显示不出来啦! 参考技术A 父节点的样式加上display:inline-block;试试 参考技术B 首先你有没有用一个大的DIV把其它的几个嵌套在里面呀 参考技术C 是父DIV的高度小的缘故吧? 你看看是不是设置了 overflow:hidden

几个并排 div 的 CSS/HTML 居中

【中文标题】几个并排 div 的 CSS/HTML 居中【英文标题】:CSS/HTML centering of several side by side divs 【发布时间】:2012-12-12 02:06:31 【问题描述】:

我正在创建一个需要将几块文本和图片并排放置的网站。但我也希望他们居中。我为这些元素中的每一个都使用了一个设置大小,所以如果有人调整他们的屏幕大小,我希望我的页面不断更改彼此相邻放置的 div 的数量。通常我会使用 float:left;为此,但这不起作用,因为我希望我的页面居中。

所以看起来有点像这样:

________
|1 2 3 4| 
|  5 6  |
|_______|

但是当我调整屏幕大小时,它看起来像这样:

______
|1 2 3|
|4 5 6|
|_____| 

如果我放大它会是这样的:

___________
|1 2 3 4 5 |
|    6     |
|__________|

目前的 css 是这样的:

 div.child
width:23%;
float:left;
height:600px;
padding:0px;
min-width:200px;
max-width:230px;
overflow:hidden;
text-align:center;
border-style:solid;
border-width:5px;
overflow:visible;
display:inline-block;

div.parrent
padding:0px;
border-style:solid;
border-top-style:solid;
border-width:5px;
overflow:hidden;
text-align:center;

有人有什么建议吗?

【问题讨论】:

以百分比给出宽度和高度! 提示:当谈到 '0' 的长度时,单位是什么并不重要,因此 CSS 允许您为了简洁起见省略它们:padding:0。为简洁起见,使用简写 border 属性:border:5px solid。如果您想使用百分比宽度而不使用填充和边框破坏您的计算,请使用 box-sizing:border-box and others 以便四个 width:25% 完全填充父项。 【参考方案1】:

将它们全部设为display:inline-block,并将父级设置为text-align:center

演示1:http://jsfiddle.net/xdEmz/1/

演示2:http://jsfiddle.net/E5sHa/2/

请注意,如果您希望每个项目中的图片居中,您可以:

将图像保留为display:inline(默认)并让text-align:center从父级流过,并使用显式<br>强制在它们之后换行,或者 您可以将图片设置为display:block(正如我在上面的第二个演示中所做的那样),然后使用margin:0 auto 使它们在其父容器中水平居中。

【讨论】:

@user1930011 不客气。请注意,如果您觉得这个答案已经完全解决了您的问题,您应该mark it as accepted。这有助于我的声誉和您的声誉,并帮助该网站的未来访问者找到对他们有帮助的答案。【参考方案2】:

使单个元素显示:内联和容器元素与文本对齐中心...这里的示例http://psarink.org/gallery.php

【讨论】:

这个确切的答案已经在两分钟前给出了。请尝试在发布前立即查看给定的答案。【参考方案3】:

您可以使用min-widthmax-widthtext-align:center 创建一个容器。

【讨论】:

以上是关于css:连续几个DIV都是position:relative;top:20px,最后一个DIV的最后一行显示不出来,正常么?怎么解决?的主要内容,如果未能解决你的问题,请参考以下文章

CSS nth-child() 给连续的几个DIV元素赋不同的背景色

JavaScript轮播图

css 左右居中问题

div里面文字不自动换行

模拟消息对话框完整版

div+css制作哆啦A梦