2016-05-23 10 views
0

私はJSONオブジェクトを返すajaxソースでJquery Dataテーブルを使用しています。そして、jqueryデータテーブルを受け入れるデータ配列にもう1つの配列があります。私のAjaxソースページ/ URIは、私が別々にそのページを開いたときに私に期待通りの応答を与えました。そのDataテーブルは空のテーブルを表示しません。これは私のページのスクリプトです。jQueryデータテーブルがajaxソースからのデータを表示しない

< script type = "text/javascript" 
 
language = "javascript" 
 
class = "init" > 
 

 
    var j = jQuery.noConflict(); 
 
var rowindex = 0; 
 
var table4; 
 
j(document).ready(function() { 
 
    //console.log('----JSONarrayJQDtable--- '+'{!JSONarrayJQDtable}'); 
 
    table4 = j('#example').DataTable({ 
 

 
    "pagingType": "full_numbers", 
 
    "searching": "true", 
 
    "aLengthMenu": [ 
 
     [10, 15, 20, 25, 50], 
 
     [10, 15, 20, 25, 50] 
 
    ], 
 
    "iDisplayLength": 10, 
 
    "sDom": 'W<"clear">lfrtip', 
 

 
    /**default orderid in asc sorting**/ 
 
    "order": [ 
 
     [0, "asc"] 
 
    ], 
 
    "bSort": false, 
 
    "bAutoWidth": false, // Disable the auto width calculation 
 
    "bFilter": false, 
 
    //"oColumnFilterWidgets": { 
 
    //"aiExclude": [ 0,2,4,5,6,7,9,10 ] 
 

 
    //}, 
 

 
    "processing": true, 
 
    "serverSide": true, 
 
    "ajax": '{!$Page.BLN_MM_TotalAppointments_HelperPage}', 
 
    "fnServerData": function(sSource, aoData, fnCallback) { 
 

 
     aoData.push({ 
 
     "name": "searchKeySBA", 
 
     "value": aoData[5].value.value 
 
     }); 
 
     console.log(aoData); 
 
     console.log('[email protected]!-aodata array---' + aoData[5].value.value); 
 

 
     $.ajax({ 
 
     "dataType": 'json', 
 
     "type": "GET", 
 
     "url": '{!$Page.BLN_MM_TotalAppointments_HelperPage}', 
 
     "data": aoData, 
 
     "success": fnCallback, 
 
     "error": function(e) { 
 
      console.log('[email protected]! DataTable Excep----- ' + e); 
 
     } 
 
     }); 
 

 
    }, 
 
    "fnPreDrawCallback": function() { 
 
     try { 
 
     var info = table.page.info(); 
 
     rowindex = parseInt(info.start); 
 
     } catch (e) {} 
 
    }, 
 

 
    "columns": [{ 
 
     data: "item", 
 
     render: function(data, type, row) { 
 
     var returnstring = ''; 
 
     console.log('---row.data--- ' + row.data); 
 
     if (row.data != undefined) { 
 
      console.log('---row.data--- ' + row.data); 
 

 
      for (i = 0; i < row.data.length; i++) { 
 
      console.log('---row.data[i].AppoitmntDate--- ' + row.data[i].AppoitmntDate); 
 
      returnstring += '<table class="inside_tbl display" width="100%"><tbody>'; 
 

 
      returnstring += '<tr>'; 
 
      returnstring += '<td class="eventlvl_bg" style=" width:16.6%;">' + row.data[i].AppoitmntDate + '</td>'; 
 
      returnstring += '<td class="grptd">'; 
 
      returnstring += '<table class="insidetkt_tbl display" width="100%">'; 
 
      returnstring += '<tbody>'; 
 
      var innerarray = []; 
 
      innerarray = row.data[i].MBEvsCorps; 
 
      if (innerarray.length != undefined) { 
 
       for (k = 0; k < innerarray.length; k++) { 
 
       if (innerarray[k].MBE != null) { 
 

 
        returnstring += '<tr>'; 
 
        returnstring += '<td class="grptd">' + innerarray[k].MBE.First_Name__c + ' ' + innerarray[k].MBE.Last_Name__c; 
 
        returnstring += '<td class="grptd">'; 
 
        returnstring += '<table width="100%" class="insidesqans_tbl el_sqans display hideRow">'; 
 
        returnstring += '<tbody>'; 
 
        var timeslotarray = []; 
 
        timeslotarray = innerarray[k].SLRvsTime; 
 
        if (timeslotarray.length != undefined) { 
 
        for (j = 0; j < timeslotarray.length; j++) { 
 
         returnstring += '<tr>'; 
 
         returnstring += '<td class="grptd">' + timeslotarray[j].timeframe + '</td>'; 
 
         returnstring += '<td class="grptd">' + timeslotarray[j].tablenum + '</td>'; 
 
         returnstring += '<td class="grptd">' + timeslotarray[j].Byrs.BLN_MM_SA_PROF_ID__r.First_Name__c + ' ' + timeslotarray[j].Byrs.BLN_MM_SA_PROF_ID__r.Last_Name__c + '</td>'; 
 
         returnstring += '</tr>'; 
 
        } 
 
        } 
 

 

 

 
        returnstring += '</tbody></table></td></tr>'; 
 
       } 
 
       } 
 

 

 
      } 
 

 

 

 

 
      returnstring += '</tbody></table></td> </tr></tbody></table>'; 
 
      } 
 

 
     } 
 

 

 

 
     return returnstring; 
 
     } 
 
    }] 
 

 

 

 
    }); 
 
}); 
 

 
< /script>

私はこのrow.data常に未定義取得しています。

これは私のサーバー側のデータ配列(DataTableの形式を受け入れる)に相当するものです。また、私は配列の配列をデータ配列に持っています。

public class AllSChedulesInner { 

    Public String AppoitmntDate {get;set;} 
    Public List<MBESLRwraper> MBEvsCorps{get;set;} 

} 

     public class TotalAppointmentsTableWraper { 

     public boolean selected {get;set;} 
     public Integer draw{get;set;} 
     public Integer recordsTotal{get;set;} 
     public Integer recordsFiltered{get;set;} 
     public List <AllSChedulesInner> data{get;set;} 


      public TotalAppointmentsTableWraper(Integer draw, Integer recordsTotal, Integer recordsFiltered, list <AllSChedulesInner> data) { 
      this.draw = draw; 
      this.recordsTotal = recordsTotal; 
      this.recordsFiltered = recordsFiltered; 
      this.data= data; 

      } 

     } 

サーバーからデータを表示するにはどうすればよいですか。

答えて

0

コンソールにエラーはありますか?

また、AJAXが2回設定されています。そのセットは1回だけ必要です。

DataTablesにはsuccesserrorの関数が組み込まれているため、正しい応答を返しても問題が発生するため、これらの関数を追加する必要はありません。

関連する問題