2
<label for="apsgender">
    <div class="join-label">Gender</div>
</label>
    <fieldset id="gender_male">
        <input type="radio" name="apsgender" value="1">
            Male
        </fieldset>
    <fieldset id="gender_female">
        <input type="radio" name="apsgender" value="2">
            Female
        </fieldset>

这是我现在正在处理的代码。使用我从另一个 stackoverflow 帖子中获取的这种方法设置我的 css 无法正常工作,因为前面使用了字段集和奇数标签。

input[type="radio"] {
    display:none;
}

label {
    display:block;
    padding-left:30px;
    font-family:Arial;
    font-size:16px;
    background: url('http://projects.opengeo.org/common/geosilk/trunk/silk/cross.png') left center no-repeat;
}

input[type="radio"]:checked + label {
    background: url('http://particletree.com/examples/buttons/tick.png') left center no-repeat;
}

我们的开发团队设置了这段代码,我想没有人尝试将图像用于单选按钮。如果可能的话,我也可以使用纯 JS,但我只能将脚本放在元素之前的正文中,而不是之后。

让我知道这是否可能。提前致谢。

我将发布我正在研究的 jsFiddle,但实际上它无处可去。http://jsfiddle.net/z25FR/1/

4

3 回答 3

4

我有一个 CSS 解决方案,但需要更改一些 HTML。

小提琴

首先,我们需要隐藏单选按钮,因为它无法设置样式:

input[type="radio"]{
    display: none;
}

然后,我们将单选按钮附近的文本设为标签:

<input id="male" type="radio" name="apsgender" value="1">
<label for="male">Male</label>

(不要忘记idandfor否则您将无法检查单选按钮)

然后,我们将标签设置为看起来像一个按钮:

input[type="radio"]+label{
    background: url('http://projects.opengeo.org/common/geosilk/trunk/silk/cross.png') left center no-repeat;
    padding-left: 30px;
}

上面的代码将直接修改单选按钮后面的标签。然后,当单选按钮为 时,我们可以将背景更改为另一个图像:checked

input[type="radio"]:checked+label{
    background-image: url('http://projects.opengeo.org/common/geosilk/trunk/silk/accept.png');
}
于 2013-06-26T14:10:15.267 回答
3

虽然这可能无济于事,但我会提到您对 HTML 的编码不正确。它应该是:

<fieldset>
 <legend>Gender</legend>
 <input type="radio" name="apsgender" id="m" value="1">
 <label for="m">Male</label>
 <input type="radio" name="apsgender" id="f" value="2">
 <label for="f">Female</label>
</fieldset>

我见过自定义单选按钮,但没有来源。但是,取决于它是如何完成的,可能会产生一些可访问性影响

于 2013-06-26T14:10:21.163 回答
2

http://jsfiddle.net/nm3uB/1/

您需要使用 Javascript 重写 HTML,然后使用 CSS 进行字段切换。一切都可以在头脑中进行,无需触摸模板。

JS:

window.onload=function(){ 
    gender_male.innerHTML='<input type="radio" name="apsgender" value="1" checked><label>Male</label>';
    gender_female.innerHTML='<input type="radio" name="apsgender" value="2"><label>Female</label>';
}

CSS:

fieldset{position:relative}
input[type="radio"]{
    opacity: 0;
    position:absolute;
}
input[type="radio"]+label{
    background: url('http://projects.opengeo.org/common/geosilk/trunk/silk/cross.png') left center no-repeat;
    padding-left: 30px;
}
input[type="radio"]:checked+label{
    background: url('http://projects.opengeo.org/common/geosilk/trunk/silk/accept.png') left center no-repeat;
    padding-left: 30px;
}
于 2013-06-26T14:39:50.590 回答