CSS 通过点击javascript/jquery 更换div border 颜色?

我想通过选择 radio 按钮更换对应的div border颜色为红色。 有没有高手指点一下?

HTML

<label ><div class="discount"><input type="radio" name="abc">2件999</div></label>
<label ><div class="discount"><input type="radio" name="abc">2件999</div></label>    

CSS

.discount{
border: 1px solid #cccccc;
padding:2px;
width:100%;
}

如截图

图片描述

阅读 5.2k
3 个回答

https://jsfiddle.net/rtf6w78b/

需要 jQuery,es6 语法

$(":radio").on("change", e => {
    const $div = $(e.target).closest(".discount");
    console.log($div);
    $(".discount").removeClass("checked");
    $div.addClass("checked");
});

css中:
.checktopup{
border: 1px solid #f00;
}
js中,记得引入jquery
$("input").on("click", function() {

    $(".discount").addClass("checktopup").siblings().removeClass("checktopup");
    window.checktopup=this;
    checked = true

})

当选项的checked值为true的时候,添加class

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏