我需要在一系列单选按钮和复选框上添加/删除一个通用类(类似于 .is-checked)。这是我的代码:
$(function () {
$('input[type="checkbox"], input[type="radio"]').each(function () {
$(this).on('click', function () {
$(this).parent().wrap('<div>').unwrap();
// works great for checkboxes, but not for radios
if ($(this).prop('checked')) {
$(this).addClass('is-checked');
} else {
$(this).removeClass('is-checked');
}
})
})
})
这在复选框上非常有效,但在添加到单选按钮的类上永远不会被删除。想法?想法?
编辑 我不小心忽略了提到这个脚本将为 IE8 有条件地加载,因为不支持 ':checked' 伪选择器。整个功能在除 IE8 之外的所有设备中都运行良好,因此这是该浏览器的拐杖,而可怜的用户则坚持使用它。最后,'is-checked' 类将触发与 :checked 选择器相同的 CSS。