Css兄弟(〜)选择器不适用于checked属性

时间:2013-04-18 00:52:40

标签: html css

为什么我的css不适合我?任何人都可以告诉我。

#slide1:checked ~ #inner { margin-left: 0;}
#slide2:checked ~ #inner { margin-left: -800px;}
#slide3:checked ~ #inner { margin-left: -1600px;}

下面的CSS确实有效。我不知道从哪里开始。

#slide1:checked ~ #broadControl label:nth-child(1),
#slide2:checked ~ #broadControl label:nth-child(2),
#slide3:checked ~ #broadControl label:nth-child(3){
    background: #333;
    border-color: #333; !important;
}

HTML:

<div id="broadcast">
    <div id="overflow">
        <div id="inner">

            <article>
                <div class="info"></div>
                <div id="pic1"></div>
                <!--img src=""-->
            </article>
            <article>
                <div class="info"></div>
                <div id="pic2"></div>
                <!--img src=""-->
            </article>
            <article>
                <div class="info"></div>
                <div id="pic3"></div>
                <!--img src=""-->
            </article>

        </div>
    </div>
</div>

<!-- Broadcast controls -->
<input checked type="radio" name="slider" id="slide1">
<input type="radio" name="slider" id="slide2">
<input type="radio" name="slider" id="slide3">
<div id="broadControl">
    <label for="slide1"></label>
    <label for="slide2"></label>
    <label for="slide3"></label>
</div>

我正在尝试使用纯CSS进行幻灯片转换,以便更好地了解CSS。

但我现在已经被困在这里3天了。

我不知道为什么它不起作用。

如果您有任何想法,请向我推荐。

提前致谢。

1 个答案:

答案 0 :(得分:11)

#slide1:checked ~ #broadControl label:nth-child(1)

~运算符仅适用于元素之后的元素。在这种情况下,#slide1#broadControl之后搜索#slide1个标签元素,它无法在之前搜索。

示例小提琴:
http://jsfiddle.net/9vxYJ/

你会在那个小提琴中看到我将你的#broadcast部分移到broadcast controls之后。

另一个问题是~兄弟选择器,这意味着它只能在同一级别找到元素。但是你可以解决这个问题,因为#broadcast#slide1处于同一级别,你可以埋葬#inner,如下:

#slide1:checked ~ #broadcast > #overflow > #inner { margin-left: 0;}
#slide2:checked ~ #broadcast > #overflow > #inner { margin-left: -800px;}
#slide3:checked ~ #broadcast > #overflow > #inner { margin-left: -1600px;}