Ошибка JQuery DataTable при рендеринге php Array на клиент - PullRequest
0 голосов
/ 27 ноября 2018

Я отправил данные json_encoded с PHP-страницы:

$arrayForDataTablePopulation = array();

        while (($row = oci_fetch_array($stid, OCI_BOTH)) != false) {

                $a = trim($row["IDCONF"]);
                $b = trim($row["NOME"]);
                $c = trim($row["TIPOLOGIA"]);
                $d = trim($row["STATO"]);
                $e = trim($row["AMBIENTE"]);
                $f = trim($row["AGGREGATORE"]);
                $f2 = trim($row["NOMECED"]);
                $g = trim($row["MODELLO"]);
                $h = trim($row["CONTRATTO"]);
                $i = trim($row["VALIDADAL"]);
                $l = trim($row["VALIDAAL"]);

            if ($count < $NUM){

                $arrayForDataTablePopulation[$count] = "[" .  $a . "," .  $b . "," . $c . "," . $d . "," . $e . "," . $f . "," . $f2 . "," . $g . "," . $h . "," . $i . "," . $l . " ]";
                $count++;

            } else {

                $arrayForDataTablePopulation[$count] = "[" .  $a . "," .  $b . "," . $c . "," . $d . "," . $e . "," . $f . "," . $f2 . "," . $g . "," . $h . "," . $i . "," . $l . " ]";

            }

        }

        echo  json_encode($arrayForDataTablePopulation);

} else {

    echo "No data Received. Dimensione array: " . $receivedArrayFormSize;

}

Я не знаю, почему мой вывод плохо отображается:

enter image description here

Мне кажется, я плохо закодировал массив с сервера.Сторона Ajax:

$.ajax({

                url: "asset_GestAsset.php",
                type: "POST",
                data: { "fieldValue" : JSON.stringify(arrForm) },
                success: function(data) {

                    var tableData = JSON.parse(data);

                    console.log(" Converti in stringhe: " + data.toString() + " !!! Everything ok");

                    $('#OUTCOME_RESEARCH_TABLE').DataTable({
                         "aaData":tableData,
                         "deferLoading": 57,
                         "deferRender": true,
                         "scrollY": 150,
                         "iDisplayLength": 100,
                         "scrollX": true,
                         "bRetrieve": true,
                         "bDestroy": true,
                         "ordering": false,
                         "info":     true,
                         "sDom":     'ltipr',
                         "bDestroy": true

                 });

etc...

Проблема в том, что я запутался со всем этим материалом Array / JSON. Думаю, сейчас у меня много путаницы в голове. XD Кто-то может помочь мне найтиКак решить эту проблему?Является ли сторона PHP неправильной или код в AJAX?

Я хотел бы изменить массив серверов, отправить обратно клиенту и правильно отобразить DataTable.

1 Ответ

0 голосов
/ 28 ноября 2018

PHP

Для заполнения массива необходимо использовать приведенный ниже код:

$arrayForDataTablePopulation[$count] = array($a, $b, $c, $d, $e, $f, $f2, $g, $h, $i, $l);

Чтобы напечатать JSON, используйте следующий код:

header('Content-type: application/json');
echo json_encode($arrayForDataTablePopulation);

JS

Используйте приведенный ниже код внутри обработчика success:

$('#OUTCOME_RESEARCH_TABLE').DataTable({
     "dom": 'ltipr',
     "data": data,
     "pageLength": 100,
     "scrollY": 150,
     "scrollX": true,
     "ordering": false
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...