zoukankan      html  css  js  c++  java
  • firefox中 checkbox属性checked="checked"已有,但复选框却不显示打钩的原因

    最近在调试复选框的应用,在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("disabled", false);
    
    //选中
    $("input[type='checkbox']").prop("checked", true);
    
    //取消
    $("input[type='checkbox']").prop("checked", false);

    在使用是将attr改为prop,问题得解。

  • 相关阅读:
    闰年or平年判断
    输入一个日期判断是否正确的几种方法
    网页布局+下拉隐藏栏
    360导航布局
    [LeetCode] Longest Common Prefix
    [LeetCode] Length of Last Word
    [LeetCode] Valid Palindrome II
    [Qt] Qt信号槽
    [LeetCode] Split Linked List in Parts
    [LeetCode] Find Pivot Index
  • 原文地址:https://www.cnblogs.com/dtdxrk/p/5546042.html
Copyright © 2011-2022 走看看