JS radio 取消选择,并触发原选择项改变事件

 $div.find("input[type='radio']").each(function () {
                    if ($(this).prop("checked") == true) {
                        $(this).attr("data-mutex-check", 'true');
                    } else {
                        $(this).attr("data-mutex-check", 'false');
                    }
                }).click(function () {
                    var check = $(this).attr("data-mutex-check");
                    var name = $(this).attr("name");
                    if (check == "true") {
                        $(this).prop("checked", false).change();                        
                        $(this).attr("data-mutex-check", "false");
                    } else {
                        //找到已经选择的项目
                        $("input[type='radio'][name='" + name + "']").each(function () {

                            if ($(this).attr("data-mutex-check") == 'true') {

                                $(this).attr("data-mutex-check", "false").change();
                            }                            
                        });
                        $(this).attr("data-mutex-check", "true");
                    }
                });

解决思路:

1.通过添加公共属性 data-mutex-check来标记当前radio状态,初始化时全部赋值一次.

2.当其中一个click时, 标记click之前选中项属性为false.当前click项属性true

3.为了触发之前选中项目已经修改.需要添加 change方法. 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三项超标

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值