html - IE7 显示 block 和宽度 : auto

标签 html css internet-explorer-7

我遇到了一个小问题,它已经困扰了我一段时间,尽管我已经尝试了很多次,但我还是无法在这里或通过谷歌找到解决方案。问题本身仅在 IE7 中存在(我不确定 IE6,但我想说结果与 IE7 有点相似)

这是我的标记:

<div class="roomsLeft">
  <a href="#" class="selectProperty button">Select</a>
  <span>Only 3 rooms left!</span>
</div>

这是上述标记的 CSS:

.roomsLeft{
    background:#fffed7;
    border-radius:5px;
    padding:1px;
    margin:15px 0 0 0;
    border:1px solid #ffd542;
    margin-right:-3px;
    width:auto;
    display:inline-block;}

.roomsLeft span{
    color:#555;
    font-size:0.7em;
    padding: 9px 8px 8px 8px;
    display:inline-block;
    width:auto;}

按钮的 CSS(如果需要):

.button {
    font-family:tahoma;
    background:#F70065;
    background:-moz-linear-gradient(top,#fb458f 0%,#F70065 100%);
    background:-webkit-gradient(linear,left top,left bottom,color-stop(0%,#fb458f),color-stop(100%,#F70065));
    background:-webkit-linear-gradient(top,#fb458f 0%,#F70065 100%);
    background:-o-linear-gradient(top,#fb458f 0%,#F70065 100%);
    background:-ms-linear-gradient(top,#fb458f 0%,#F70065 100%);
    background:linear-gradient(top,#fb458f 0%,#F70065 100%);
     /* For Internet Explorer 5.5 - 7 */ 
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#fb458f, endColorstr=#F70065 ); 
    /* For Internet Explorer 8 */ 
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#fb458f, endColorstr=#F70065 )";
    padding:7px 9px;
    color:#fff;
    font-size:0.7em;
    border-radius:4px;
    -moz-border-radius:4px;
    -webkit-border-radius:4px;
    border:1px solid #DD005B;
    font-weight:800;
    text-decoration:none;
    letter-spacing:0em;
    text-shadow:1px 0px 5px #DD005B;
    box-shadow:inset 0px 1px rgba(255,255,255,0.2);}

.button:hover {
    background:#F70065;
    background:-moz-linear-gradient(top,#fb458f 0%,#F70065 100%);
    background:-webkit-gradient(linear,left top,left bottom,color-stop(0%,#fb458f),color-stop(100%,#F70065));
    background:-webkit-linear-gradient(top,#fb458f 0%,#F70065 100%);
    background:-o-linear-gradient(top,#fb458f 0%,#F70065 100%);
    background:-ms-linear-gradient(top,#fb458f 0%,#F70065 100%);
    background:linear-gradient(top,#fb458f 0%,#F70065 100%);
     /* For Internet Explorer 5.5 - 7 */ 
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#fb458f, endColorstr=#F70065 ); 
    /* For Internet Explorer 8 */ 
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#fb458f, endColorstr=#F70065 )";
    padding:7px 9px;
    color:#fff;
    font-size:0.7em;
    border-radius:4px;
    -moz-border-radius:4px;
    -webkit-border-radius:4px;
    border:1px solid #DD005B;
    font-weight:800;
    text-decoration:none;
    letter-spacing:0em;
    text-shadow: 0 0 5px rgba(255,255,255,0.7);
    box-shadow:inset 0px 1px rgba(255,255,255,0.2), 0 0 5px rgba(247, 0, 101, 0.5);}

这是它在所有其他主要浏览器(IE8-10、Chrome、FF 和 Opera)中的样子:

http://jsfiddle.net/vpF27/

无论父容器的宽度如何,父容器的宽度只会延伸到它的子容器的组合宽度,但是......在浏览 IE7 和他的哥哥们以破坏这个地方并决定

.roomsLeft

需要填充整个父级,任何父级。

现在我已经尝试将罪魁祸首从我的元素上下文中移除(并远离任何其他可能干扰的元素)并在单独的文件中运行 css 和 html,希望缩小任何问题的范围,但不幸的是这没有解决任何问题,问题仍然存在。

你们能提供的任何帮助都会很棒。

谢谢。

编辑:希望这 fiddle提供了更多有关 IE7 内部情况的上下文。在所有其他浏览器中,添加

display:block;

.roomsLeft

解决问题

最佳答案

试试这个方法:

.button { display:inline-block; *display:inline; zoom:1;  /*float:right;*/ }

JSFiddle

去掉 float ,用display-inline-block改变它;并切换元素的 html 位置。

关于html - IE7 显示 block 和宽度 : auto,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18042148/

相关文章:

javascript - 设置 td 检查属性

html - 如何保持响应图像相同的高度?

css - ie7 中的导航栏悬停问题

javascript - 为什么 IE7 javascript array.indexOf 不工作?

html - IE8 不透明度问题

javascript - HTML5 Canvas 幻灯片放映问题

html - css定位子div

javascript - 更改 div bgcolor onkeypress

html - 页脚不粘

html - Flex 内容可以强制父网格元素的宽度吗?