我遇到了一个奇怪的问题(仅限于ie7),右浮动元素的左浮动子元素没有被约束到其父元素的宽度,而是一直到父元素的最左边,停在最接近的左浮动div处。在其他浏览器中看起来都不错,但不幸的是我必须支持ie7。
有没有办法在不设置两个浮动子项的父项的显式宽度和不更改标记结构的情况下修复此问题?
http://jsfiddle.net/s89XZ/
小提琴代码如下:
<style>
.wrapper{
position: relative;
width: 500px;
min-height: 18px;
margin: 0 auto;
padding: 14px 0;
background-color: red;
}
.menu_L{
color: #504A43;
height: 18px;
float: left;
width: 100px;
background-color: blue;
}
.menu_R_wrapper{
float: right;
}
.menu_R{
position: relative;
float: right;
}
.menu_R .item_L,
.menu_R .item_R{
width: 50px;
height: 18px;
}
.menu_R .item_L{
float: left;
background-color: orange;
}
.menu_R .item_R{
float: right;
background-color: green;
}
</style>
<div class="wrapper">
<div class="menu_L"></div>
<div class="menu_R_wrapper">
<div class="menu_R">
<div class="item_L"></div>
<div class="item_R"></div>
</div>
</div>
</div>
最佳答案
您必须在较小的IE中设置浮动父级的宽度:请参见http://jsfiddle.net/s89XZ/1/添加此宽度的位置(此处应为100px,但105px更适合显示其工作情况):
.menu_R {
width: 105px;
}