iCheck的全选和获取value

在使用jQuery iCheck 插件的时候遇到了一个问题,就是当我们使用普通的js全选功能无效了。

$("#checkall").click(
        function(){
            if(this.checked){
                $("input[name=‘checkname‘]").each(function(){this.checked=true;});
            }else{
                $("input[name=‘checkname‘]").each(function(){this.checked=false;});
            }
        }
    );

这样来写对默认的checkbox框没问题,但是当使用iCheck 插件后将无效。

那么该怎么解决呢?

最后是在stackoverflow 找到的解决方法:

地址是这里: http://stackoverflow.com/questions/17820080/function-select-all-and-icheck

//全选获取数值
    var checkAll = $(‘input.all‘);
    var checkboxes = $(‘input.check‘);
    checkAll.on(‘ifChecked ifUnchecked‘, function(event) {
        if (event.type == ‘ifChecked‘) {
            checkboxes.iCheck(‘check‘);
        } else {
            checkboxes.iCheck(‘uncheck‘);
        }
    });
    checkboxes.on(‘ifChanged‘, function(event){
        if(checkboxes.filter(‘:checked‘).length == checkboxes.length) {
            checkAll.prop(‘checked‘, ‘checked‘);
        } else {
            checkAll.removeProp(‘checked‘);
        }
        checkAll.iCheck(‘update‘);
    });

在解决了全选问题后,又遇到了一个新的问题,获取选中的checkbox的value的时候,使用:$(this).attr(‘checked‘);获取不到值了~,蛋疼。

最后几经Google搜索,还是在stackoverflow 找到了启发,判断checkbox的布尔值,使用 :$(this).is(‘:checked‘);

最后代码的解决方法如下:

$(".ajax-delete").click(function(){
    var url = $(this).attr(‘data-url‘);
    var str="";
    var ids="";
    $("input[name=‘id‘]:checkbox").each(function(){
        if(true == $(this).is(‘:checked‘)){
            str+=$(this).val()+",";
        }
    });
    if(str.substr(str.length-1)== ‘,‘){
        ids = str.substr(0,str.length-1);
    }
    console.log(ids);
});

延伸:

1.判断已选中的个数/长度

var len = $("input[name=‘id‘]:checkbox").length;

来自:http://www.tuicool.com/articles/aANRBv

官网:http://www.bootcss.com/p/icheck/

时间: 2024-11-03 03:28:53

iCheck的全选和获取value的相关文章

BootStrap iCheck插件全选与获取value值的解决方法

这篇文章主要介绍了BootStrap iCheck插件全选与获取value值的解决方法,解决方法其实很简单,下面小编给大家分享下这方面的知识 在使用jQuery iCheck 插件的时候遇到了一个问题,就是当我们使用普通的js全选功能无效了. $("#checkall").click( function(){ if(this.checked){ $("input[name='checkname']").each(function(){this.checked=tru

bootstrap iCheck插件 全选和获取value值的解决方法

在使用jQuery iCheck 插件的时候遇到了一个问题,就是当我们使用普通的js全选功能无效了. $("#checkall").click(     function(){         if(this.checked){             $("input[name='checkname']").each(function(){this.checked=true;});         }else{             $("input[

JQuery 判断checkbox是否选中,checkbox全选,获取checkbox选中值

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

jquery1.11 操作checkbox:全选、取消全选、获取选择元素、获取取消选择元素(总结)

jquery1.11.1版本完成对checkbox的操作 1. 使用属性prop设置选中状态 2.使用:checked和:not(:checked)获取选中的元素 源码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1&quo

Jquery 实现动态添加table tr 和删除tr 以及checkbox的全选 和 获取添加TR删除TR后的数据

关于jquery实现动态添加table tr的问题我也不多说了 上面代码很多地方都有注释的 关于返回的 编辑后的table 数据 我这里想说的是我直接把他保存成一个连接起来的字符串了 格式 str=XXX | XXX | XXX , XXX | XXX | XXX , XXX | XXX | XXX 你也可以保存成对象类型的  我是为了方便后台的操作才这样做的 话不多说直接代码: <html> <head> <meta http-equiv="Content-Typ

分享知识-快乐自己:复选框、全选/反选/获取值

1):复选框 全选与反选 .获取选中的值 取消选中的框 1.全选/反选 <body> <input type="checkbox" checked> <input type="checkbox"> <input type="checkbox"> <input type="checkbox"> <input type="checkbox">

Android高级控件(一)——ListView绑定CheckBox实现全选,添加和删除等功能

Android高级控件(一)--ListView绑定CheckBox实现全选,添加和删除等功能 这个控件还是挺复杂的.也是项目中应该算是比較经常使用的了,所以写了一个小Demo来讲讲,主要是自己定义adapter的使用方法.加了非常多的推断等等等等-.我们先来看看实现的效果吧! 好的,我们新建一个项目LvCheckBox 我们事先先把这两个布局写好吧,一个是主布局,另一个listview的item.xml.相信不用多说 activity_main.xml <LinearLayout xmlns:

关于checkbox全选与反选的问题

在一组checkbox中常有这样的需求,选择全选按钮,所有的选项必须全选上,当再次点击时,则所有的按钮必须反选,当点击一组checkbox时,只有有一个不选上,则按钮不选中,当所有的按钮全部选上时,此时全选按钮就选上,具体代码的思路如下: 1:触发全选按钮获取全选按钮的checked布尔值,将全选按钮的全选布尔值传给其他子序列checkbox,从而控制所有的checkbox 2:触发所有子选项checkbox,循环选择所有子选项的checkox布尔状态,当所有的子选项checkbox只要一项不选

python 自动化测试多选框全选

def click_checkbox(self): ''' 多选框全选操作 获取全部的多选框,一定要用elements, 然后遍历,循环点击 防止反选,is_selected判断是否选中 选中返回True,否则返回False :return: ''' self.driver.get(r'E:\测试2\资料\radio.html') checkbox = self.driver.find_elements_by_xpath('//input[@type="checkbox"]') for