zoukankan      html  css  js  c++  java
  • easyui 中combogrid 实现多选,反选效果

    实现EasyUI Combogrid组件的多选和反选效果

    1.html 代码

    <input id="roadClass"  name="road" />

    <div id="Toolbutton" style="padding: 5px;">
    <label class="mr-10" id="allChoose">全选</label>
    <label id="unChoose">反选</label>
    </div>

    2.js代码

    // 渠道来源
    $('#roadClass').combogrid({
    multiple: true, //设置允许多选
    panelWidth:150,
    panelHeight:300,
    idField:'id',
    textField:'text',
    data:road, //调用json数据
    toolbar:'#Toolbutton',
    showHeader:false,  //隐藏标头
    checkOnSelect:true,
    columns:[[
    {
    field: 'id',
    title: 'Toolbutton',
    align:'center',
    checkbox:true
    },{
    field: 'text',
    title: '选择',
    120
    }
    ]]
    });
    $('#roadClass').next('span').eq(0).children('input').attr('placeholder','所有');
    var flag=false; //设置全选的开关
    $('#allChoose').click(function(){
    $(this).toggleClass('fontRed fb pointer');  //切换类,这块设置的是全选点击的样式
    if(flag==true){
    $('#roadClass').combogrid('grid').datagrid('checkAll');
    flag=false;
    }else{
    $('#roadClass').combogrid('grid').datagrid('uncheckAll');
    flag=true;
    }

    });

    $('#unChoose').click(function(){
    var nodes=$('#roadClass').combogrid('grid').datagrid('getChecked'); //注意 combogrid中利用datagrid中方法的选取方式
    var arr=[];
    for(var i=0;i<nodes.length;i++){
    var index=$('#roadClass').combogrid('grid').datagrid('getRowIndex',nodes[i]);
    arr.push(index);
    }
    $('#roadClass').combogrid('grid').datagrid('checkAll');
    for(var j=0;j<arr.length;j++){
    $('#roadClass').combogrid('grid').datagrid('uncheckRow',arr[j]);
    }
    });

    css代码:

    .pointer{cursor: pointer;}

    .fb{font-weight: bold;}

    .fontRed{ color: red;}

    json数据:

    var road=[
    {"id":"1","text":"1"},
    {"id":"2","text":"2"},
     

    注意点:

    1.一般情况下我们设置datagrid很少隐藏列标头, 设置 showHeader:false,可以隐藏标头

    2.在任何未选中的情况下设置默认显示‘’所有‘’  $('#roadClass').next('span').eq(0).children('input').attr('placeholder','所有');  

    3.combogrid情况下,利用datagrid中的方法: $('#roadClass').combogrid('grid').datagrid('方法'); 

  • 相关阅读:
    javascript中的this和e.target的深入研究
    mysql基础
    php每天一题:怎么在不使用第三个变量的情况下交换两个变量的值
    用原生javascript实现在页面动态显示时间
    php每天一题:strlen()与mb_strlen()的作用分别是什么
    javascript每天一题
    php中用foreach改变数组的值的问题
    程序员进阶之路
    hdu6638 线段树求最大子段和
    P4513 小白逛公园 动态维护最大子段和
  • 原文地址:https://www.cnblogs.com/wenyan/p/9367432.html
Copyright © 2011-2022 走看看