CSS选择器:在IE8中激活不在子元素上单击

时间:2011-10-19 11:39:20

标签: html css internet-explorer-8 css-selectors

我有以下HTML结构:

<div id="ctr__Wrapper" class="wrapper">
    <div id="ctr" class="control clickable">
        <img src="logo.png">
    </div>
</div>

以下CSS:

.control
{
    border: 1px solid #000;
    background-color: #666;
    padding: 20px;
}

.control:active
{
    background-color: #bbb;
}

当我点击元素“ctr”时,我看到背景颜色发生了变化,但是当我点击图像本身时,却没有。这适用于Firefox,但不适用于IE8。我可以做些什么来解决这个问题。

这里可以看到工作示例: http://jsfiddle.net/miljenko/DNMPd/

2 个答案:

答案 0 :(得分:2)

您可以使用背景图片而不是真实图片。

HTML:

<div id="ctr__Wrapper" class="wrapper">
    <div id="ctr" class="control clickable">
    </div>
</div>

的CSS:

.control
{
    border: 1px solid #000;
    background-color: #666;
    height: 40+height-of-logopx;
    background-image:url(logo.png); background-repeat:no-repeat;
    background-position:20px 20px;
}

.control:active
{
    background-color: #bbb;
}

答案 1 :(得分:0)

因为&lt; ie9不支持:在锚元素以外的任何东西上激活。这是你的小提琴,应该在ie8 http://jsfiddle.net/jalbertbowdenii/DNMPd/12/

中起作用