esolve
V2EX  ›  问与答

Checkbox 的 checked 属性为 false 了,但是还是显示打钩怎么办?

  •  
  •   esolve · Dec 13, 2017 · 2348 views
    This topic created in 3076 days ago, the information mentioned may be changed or developed.

    有多个 checkbox 只能选择一个 当有两个都被勾选,最后选的会让之前选的被取消打钩 我用下面的方法

            $(':checkbox[type="checkbox"]').each(function(){
                $(this).click(function(){
                    if($(this).prop('checked')){
                        $(':checkbox[type="checkbox"]').removeAttr('checked');
                        $(this).prop('checked','true');
                    }
                });
            });
    

    可是调试发现 前面的勾选依然显示打钩,虽然他们的属性 checked 为 false 了 怎么回事?

    esolve
        1
    esolve  
    OP
       Dec 13, 2017
    顶顶顶
    Fishdrowned
        2
    Fishdrowned  
       Dec 13, 2017
    前面是 $(this).prop('checked'),后面是 .removeAttr('checked'),少年你的内心很矛盾啊。

    把 .removeAttr('checked') 改成 .prop('checked', false);
    esolve
        3
    esolve  
    OP
       Dec 14, 2017 via iPhone
    @Fishdrowned 试过,没用,效果一样的啊,
    esolve
        4
    esolve  
    OP
       Dec 14, 2017
    @Fishdrowned 说错了,

    我之前用的是

    $(':checkbox[type="checkbox"]'). .prop('checked', false);

    这个不仅显示没有取消打钩
    连属性 checked 都继续为 true
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2866 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 12:28 · PVG 20:28 · LAX 05:28 · JFK 08:28
    ♥ Do have faith in what you're doing.