checkbox标签的一些用法(jQuery操作)

//监听选中事件
$("#checkbox1").change(){
    //判断是否为选中状态
    //也可以这样$(this).prop("checked")
    if($(this).is(":checked")){
        //do something
    }else{
        //other
    }
}
//改变checkbox的状态
$("#checkbox1").prop("checked",true);
//或者
$("#checkbox1").prop("checked",false);
//获取选中的checkbox
var selecteds=$("input:[type='checkbox']:checked");

为什么不使用attr()方法?
对于表单元素的checked、selected、disabled等属性,在jQuery 1.6之前,attr()获取这些属性的返回值为Boolean类型:如果被选中(或禁用)就返回true,否则返回false。

但是从1.6开始,使用attr()获取这些属性的返回值为String类型,如果被选中(或禁用)就返回checked、selected或disabled,否则(即元素节点没有该属性)返回undefined。并且,在某些版本中,这些属性值表示文档加载时的初始状态值,即使之后更改了这些元素的选中(或禁用)状态,对应的属性值也不会发生改变。

因为jQuery认为:attribute的checked、selected、disabled就是表示该属性初始状态的值,property的checked、selected、disabled才表示该属性实时状态的值(值为true或false)。

因此,在jQuery 1.6及以后版本中,请使用prop()函数来设置或获取checked、selected、disabled等属性。对于其它能够用prop()实现的操作,也尽量使用prop()函数。

attr()和prop()方法的更多区别:http://www.365mini.com/page/jquery-attr-vs-prop.htm

发布了31 篇原创文章 · 获赞 37 · 访问量 14万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章