miniui反选

miniui中,如果行数据进行过合并,那么在数据全选的时候,就会出现问题,研究之后,发现可以用下面的方法解决:

<div id="datagrid" class="mini-datagrid" style="width:100%;height:100%;" visible="true" 
           onselectionchanged="onSelectionChange" 
           ondeselect="deselect" onselect="select">
    function onSelectionChange() {
            var rows = grid.getSelecteds();
            unselectedList = dedupe(unselectedList);
            for (var unidx = 0; unidx < unselectedList.length ; unidx ++ ){
                var sidx = rows.length;
                while(sidx--){
                     if(rows[sidx].deliveryid == unselectedList[unidx]){
                         rows.splice(sidx,1);
                     }
                }
            }
            for(var i = 0 ; i < rows.length ; i ++ ){
               //此时的rows为选中数据
            }

        }

 

    //反选
        function deselect(sender){
            unselectedList.push(sender.record.deliveryid); 
        }

        //选中
        function select(sender){
            selectedList = sender.record.deliveryid; 
            unselectedList = dedupe(unselectedList);
            var idx = unselectedList.length;
            while(idx--){
                   if(unselectedList[idx] ==  selectedList){
                       unselectedList.splice(idx,1);
                   }
               }
        }

        //去重
        function dedupe(array){
           return Array.from(new Set(array));
        }

 

转载于:https://www.cnblogs.com/xiaoQ0725/p/9254525.html

你可能感兴趣的:(miniui反选)