zoukankan      html  css  js  c++  java
  • 解决jquery操作checkbox全选全不选无法勾选问题

    解决jquery操作checkbox全选全不选无法勾选问题

    最近在工作中使用jquery操作checkbox,使用下面方法进行全选、反选:
    $("input[name='checkbox']").attr("checked","checked");
    调试时,前两次都没有问题,可以正常显示选中和取消,但当再去选中的时候,复选框的属性checkbox值变为"checked",没问题,但是复选框却不在显示选中状态,明明属性值改了,但是却不显示勾选,太诡异了。代码修改了却得不到正确的显示状态,纠结了很久,找不到原因。

    于是乎各种找原因,后来在网上搜到一篇文章提醒了我,原来是jQuery版本问题。
    我操作属性用的是
    $("XXX").attr("attrName");而jQuery的版本用的是2.1.1,这就是存在一个兼容性和稳定性问题。
    jQuery API明确说明,1.6+的jQuery要用prop,尤其是checkBox的checked的属性的判断,即
    使用代码如下:

    $("input[name='checkbox']").prop("checked");
    $("input[name='checkbox']").prop("disabled", false);
    $("input[name='checkbox']").prop("checked", true);

    于是乎将attr改为prop,问题得解。
    如果您遇到这个奇怪的问题那就赶紧试试吧!

  • 相关阅读:
    【坑】提答题
    Google Code Jam 2014 Round2
    湖北省队互测Week1
    [xyz模拟题]动态维护树的直径
    音乐会的等待【单调栈】
    51nod1202【DP-树状数组维护】
    51nod1113【矩阵快速幂】
    51nod1255【贪心-栈的应用】
    Lightoj1059【最小生成树】
    SPOJ IAPCR2F 【并查集】
  • 原文地址:https://www.cnblogs.com/ching2009/p/4704682.html
Copyright © 2011-2022 走看看