Я пытаюсь отформатировать jQuery DataTable, используя json, хранящийся в базе данных. Я передаю JSON клиенту в скрытом поле в ответе. Затем я пытаюсь инициализировать данные следующим js:
function initDataTables(){
$('.datatable').each(function(i) {
// Look for a hidden field containing the json to use when initialising the datatable
var hiddenfieldkey = $(this).attr('id') + 'jsoninit'
var hiddenfield = $('#' + hiddenfieldkey);
if (hiddenfield.length > 0) {
// We have found some 'special' json formatting, so use it
var jsoninittext = $(hiddenfield).val();
alert(jsoninittext);
var json = $.parseJSON(jsoninittext);
alert('point two');
$(this).dataTable(json);
}
else {
// Standard datatable formatting
$(this).dataTable({
"bJQueryUI": true,
"sPaginationType": "full_numbers",
"aLengthMenu": [[10, 25, 50, -1], [10, 25, 50, "All"]]
});
}
});
initDataTableButtons();
}
Все это прекрасно работает со следующим json (я только что скопировал sql, который я использую для заполнения таблицы инициализации json в db:
update query set jQueryDatatableJSONInit=
'{
"iDisplayLength": 25
,"bJQueryUI": true
,"sPaginationType": "full_numbers"
,"aLengthMenu": [[10, 25, 50, -1], [10, 25, 50, "All"]]
,"aoColumnDefs": [
{ "bVisible": false, "aTargets": [ 0,3,4 ] }
,{ "sClass": "nowrap", "aTargets": [ 2 ] }
,{ "iDataSort": 0, "aTargets": [ 1 ] }
,{ "bSortable": false, "aTargets": [ 2 ] }
]
}'
where id ='336f7ea2-173a-4b8f-af30-e217d1e1c628'
Однако проблема возникает, когда в моем json есть функция, как показано ниже (как и раньше, но содержит строку fnRender, содержащую функцию):
update query set jQueryDatatableJSONInit=
'{
"iDisplayLength": 25
,"bJQueryUI": true
,"sPaginationType": "full_numbers"
,"aLengthMenu": [[10, 25, 50, -1], [10, 25, 50, "All"]]
,"aoColumnDefs": [
{ "fnRender": function ( oObj ) { return oObj.aData[2] +'' ''+ oObj.aData[3]+'' ''+ oObj.aData[4];},"aTargets": [ 2 ]}
,{ "bVisible": false, "aTargets": [ 0,3,4 ] }
,{ "sClass": "nowrap", "aTargets": [ 2 ] }
,{ "iDataSort": 0, "aTargets": [ 1 ] }
,{ "bSortable": false, "aTargets": [ 2 ] }
]
}'
where id ='336f7ea2-173a-4b8f-af30-e217d1e1c628'
Сбой следующей строки (с ошибкой JSON):
var json = $.parseJSON(jsoninittext);
и поэтому второе предупреждение (пункт два) никогда не запускается, поэтому оно не попадает в функцию dataTable (). Мне кажется, что определение функции (содержащее фигурные скобки) делает json недействительным.
Кто-нибудь знает, как я мог отформатировать инициализируемую датами json, чтобы она продолжала содержать определение функции, как ожидается от jquery datatables, но это все еще будет действительный json (есть ли своего рода выход, который я могу использовать)?
Большое спасибо.