wild84 2017-11-27 09:58 采纳率: 83.3%
浏览 897
已采纳

jquery选择器有时效性吗?

我的需求是"点击某行,这个行前面的复选框选中"

$("tbody",$table).on("click","tr",function (event) {
        $(this).toggleClass("active");
        var item=_table.row($(this).closest("tr")).data();
        if($(this).hasClass("active")){
            alert(1);
            $table.find("input[value='"+item.id+"']").attr("checked",true);
        }else{
            alert(2);
            $table.find("input[value='"+item.id+"']").attr("checked",false);
        }
    });

这段代码只生效第一次,第二次就没有反映了;
加了alert();
alert语句都能正常弹出,但是复选框的状态就是没有改变.

  • 写回答

4条回答 默认 最新

  • #麻辣小龙虾# 2017-11-27 14:01
    关注

    你这个问题我有遇到过,你仔细看下jq文档attr()和prop()的区别,其实也就是属性和特性的区别。,而prop是用于设置属性用的,表单元素select或者checkbox radio、设置checked的值得时候建议使用prop设置,不然你会看到,虽然使用attr移出或者设置check属性,但是我们眼镜有时后似乎看不到变化,但是表单在提交数据的时候也会将数据提交到务器服(),如果是用prop设置的就不会出现这样的情况,关于属性和特性的区别,建议你看下

    http://bbs.csdn.net/topics/392140605

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?