最近在用jquery的datatable做项目,期间遇到一个需要生成多组单选按钮组的问题,且每一个单选按钮组的name均不相同,当然就想到用循环 去生成这些单选按钮组。生成单选按钮组本身没有任何问题,不过,当再次刷新列表界面时,生成的单选按钮组的name的下标就会变化。想要让循环变量从0开 始再进行循环,此时需要用到datatable的两个属性:preDrawCallback(刷新之前调用)和drawCallback(刷新之后调 用)。示例代码如下:

$(function () {

    var taskId = $('#taskId').val();

    var taskKey = $('#taskKey').val();

    var savedOptionArray = new Array();

    var savedCommentArray=new Array();

    var xmhzListIdx = -1;

    //datatable

    oTable = $('#dataTable').dataTable({

        "aaSorting": [

            [ 1, "desc" ]

        ],//排序设置

        "preDrawCallback": function( settings ) {

        savedOptionArray = new Array();

         for (var k= 0; k <= xmhzListIdx; k++) {

         var projectId = $("#hid_projectId_" + k).val();

         

         if (projectId) {

        var optionVal = 0;

        var comment= $("#hid_comment_" + projectId).val();

        if (document.getElementById("option_"+projectId+"_agree").checked) {

        optionVal = 1;

        savedCommentArray["ID" + projectId] = comment;

        } else if (document.getElementById("option_"+projectId+"_needEdit").checked) {

        optionVal = 2;

        savedCommentArray["ID" + projectId] = comment;

        } else if (document.getElementById("option_"+projectId+"_delete").checked) {

        optionVal = 3;

        savedCommentArray["ID" + projectId] = comment;

        }

        savedOptionArray["ID" + projectId] = optionVal;

         }

         }

         xmhzListIdx = -1;

        },

        "drawCallback": function( settings ) {

        for(var key in savedOptionArray){

        var projectIdLoop = key.substr(2);

            var checkV = savedOptionArray[key];

           

            if (checkV == 1) {

            $("#option_"+projectIdLoop+"_agree").attr("checked", "checked");

            $("#auditOpinion").val(savedCommentArray[key]);

            $("#hid_comment_" + projectIdLoop).val(savedCommentArray[key]);

            } else if (checkV == 2) {

            $("#option_"+projectIdLoop+"_needEdit").attr("checked", "checked");

            $("#auditOpinion").val(savedCommentArray[key]);

            $("#hid_comment_" + projectIdLoop).val(savedCommentArray[key]);

            $("#hid_commentId_" + projectIdLoop).css('display','block'); 

            } else if (checkV == 3) {

            $("#option_"+projectIdLoop+"_delete").attr("checked", "checked");

            $("#auditOpinion").val(savedCommentArray[key]);

            $("#hid_comment_" + projectIdLoop).val(savedCommentArray[key]);

            $("#hid_commentId_" + projectIdLoop).css('display','block'); 

            }

            }

        },

        "ajax": {

            "url": __CONTEXT__ + "/institute/xmylxHuizhong!list",

            "type": "POST",

            "data" : {

'taskId' : taskId,

'taskKey' : taskKey,

},

            //后台传递参数

//"data": function ( d ) {

//var searchCondition = $("#projectgress").serializeArray();

//var searchResult = initialSearchCondition(searchCondition, d);

//        return searchResult;   

//},

        },

        "aoColumns": [

{   

   "mData":"projectName",

   },

   {   

   "mData":"applyPersonName",

   },

   {   

   "mData":"deptCodeName",

   },

   {   

   "mData":"specializedFieldName",

   },

   {   

       "mData":"projectPreliminary.summary",

   },

   {   

   "mData":"projectPreliminary.innovation",

   },

   {   

   "mData":"projectPreliminary.goal",

   },

   {   

   "mData":"projectPreliminary.cost",

   },

            {

                "mData": "projectId",

                "sortable": false,//控制单列的排序

                "mRender": function (data, type, full) {

                    return '<a href="javascript:void(0)"  + data + ');">编辑</a>';

                }

            },

            {

"mData":"projectId",

"sortable": false,//控制单列的排序

"mRender": function ( data, type, full ) {

xmhzListIdx ++;

   return '<input type="radio" id="option_'+data+'_agree" value="agree" name="option['+xmhzListIdx+']">同意&nbsp;'+

                               '<input type="radio" id="option_'+data+'_needEdit" value="needEdit"  name="option['+xmhzListIdx+']">需要修改&nbsp;'+

                               '<input type="radio" id="option_'+data+'_delete" value="delete"  name="option['+xmhzListIdx+']">删除'+

                               '<input type="hidden" id="hid_projectId_'+xmhzListIdx+'" name="projectId['+xmhzListIdx+']" value="'+data+'">'+

                               '<input type="hidden" id="hid_comment_'+data+'" name="comment['+xmhzListIdx+']">'+

                               '<a href="javascript:void(0)" id="hid_commentId_'+data+'" style="display:none;" name="commentId['+xmhzListIdx+']" οnclick="addAndEditComment('+xmhzListIdx+');">修改意见</a>';

}

},

        ],

        "bFilter": false,

        "bInfo": true,

        "bPaginate": true,

        "bProcessing": true,

        "bSort": true, //排序

        "fnRowCallback": function (nRow, aData, iDisplayIndex) {

            /* Append the grade to the default row class name */

            //渲染完表格后的处理事件

            if (aData[2] == "1") {

                $('td:eq(2)', nRow).html('<b>A</b>');

            }

            return nRow;

        },

        "bServerSide": true,

        "oLanguage": {

            "sLengthMenu": "每页显示 _MENU_ 条",

            "sZeroRecords": "没有找到符合条件的数据",

            //"sProcessing": "<img src=’./loading.gif’ />",

            "sInfo": "当前第 _START_ - _END_ 条 共计 _TOTAL_ 条",

            "sInfoEmpty": "没有记录",

            "sInfoFiltered": "(从 _MAX_ 条记录中过滤)",

            "sSearch": "搜索",

            "sProcessing": "加载中...",

            "oPaginate": {

                "sFirst": "首页",

                "sPrevious": "前一页",

                "sNext": "后一页",

                "sLast": "尾页"

            }

        },

        "bLengthChange": false, //用户不可改变每页显示数量

        "iDisplayLength": 10, //每页显示10条数据

        "sPaginationType": "full_numbers",//分页 页脚以  数字方式分页

    });

    return;

});