zoukankan      html  css  js  c++  java
  • 火狐,谷歌浏览器checkbox全选的问题

    在工作中使用jquery操作checkbox,进行全选、反选,现在的问题是火狐下第二次无法勾选问题,在下面有个详细的解答,感兴趣的朋友可以参考下
     

    最近在工作中使用jquery操作checkbox,使用下面方法进行全选、反选:

    复制代码 代码如下:

    var ischecked=allCheckObj.is(':checked');
    ischecked?checksObj.attr('checked',true):checksObj.attr('checked',false);


    调试时在ie没有问题,考虑到兼容性,试试了firefox,遇到了问题。于是乎,做了如下实验:
    复 选框绑定了click事件,点一次选中,再点击取消选中,依次类推。这个功能在ie中没问题,但是在firefox中测试的时候,前两次都没有问题,可以 正常显示选中和取消,但当再去选中的时候,复选框的属性checkbox值变为"checked",没问题,但是复选框却不在显示选中状态,明明属性值改 了,但是却不显示勾选,太诡异了。代码修改了却得不到正确的显示状态,纠结了很久,找不到原因。
    正解:后来经偶像指点,原来是jQuery版本问题。我操作属性用的是
    $("**").attr("attrName");而jQuery的版本用的是1.9,这就是存在一个兼容性和稳定性问题。
    jQuery API明确说明,1.6+的jQuery要用prop,尤其是checkBox的checked的属性的判断,即

    复制代码 代码如下:


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

  • 相关阅读:
    Appium:四:控件
    Appium:三:APP元素定位
    jmeter分布式踩得坑汇总
    Linux环境下进行分布式压测踩过的坑
    记录一次余额迁移的坑(测试角度)
    记录性能测试脚本开发的过程
    jmeter如何设置全局变量
    性能测试,如何得到大量token,并保存在本地文件中
    小程序测试心得
    测试管理三
  • 原文地址:https://www.cnblogs.com/xunfang123/p/4231941.html
Copyright © 2011-2022 走看看