jqGrid — PHP / mySQL (что-то пропустили?)

PHP-код:

$Re = $ZD -> query($PullSearchInfoSQL);
$Rn = $ZD -> found_rows;
if($Rn > 0 && $limit > 0){$Rn = ceil($Rn/$limit);}else{$Rn = 0;}
if($page > $Rn) $page = $Rn;
$start = $limit * $page - $limit;
$Re = $ZD -> query($PullSearchInfoSQL.' LIMIT '.$start.','.$limit);
while($Ro = $ZD -> fetch_assoc($Re)){
$PullSearchInfoData[] = array('X' => Coords($Ro['SCFieldID']),'P' => $Ro['SCPlayer'],'C' => $Ro['SCCastle'],'F' => $Ro['SCFlag'],'A' => $Ro['SCAlliance'],'S' => PlayerStatus($Ro['SCStatus']),'D' => $Ro['SCSnapA']);
}
$PullSearchInfoData = array('page' => $page,'num' => $Rn,'cell' => $PullSearchInfoData);
echo json_encode($PullSearchInfoData);

jqGrid:

$('#PlayerInformation').jqGrid({
url: DateFile+'Data.php?Load=PullSearchInfo&MOpt='+MOpt+'&Data='+$('#SearchThis').val()+'&Parm='+$('#SearchOption').val().split('^')[0]+'&Opts='+$('#SearchOption').val().split('^')[1],
datatype:'json',
colModel:[
{label:'X , Y',name:'X',width:44,align:'left',sortable:false},
{label:'Player',name:'P',width:68,align:'left',sortable:false},
{label:'Castle',name:'C',width:68,align:'left',sortable:false},
{label:'Flag',name:'F',width:28,align:'left',sortable:false},
{label:'Alliance',name:'A',width:68,align:'left',sortable:false},
{label:'S',name:'S',width:10,align:'center',sortable:false},
{label:'Date',name:'D',width:77,align:'center',sortable:false}
],
rowNum:1000, altRows:true, height:507, pager:'#PlayerInfoPager',
loadComplete: function(){
$('#AllPlaTitle').empty().html('History for [ '+$('#SearchThis').val()+ ' ] '+$(this).jqGrid('getGridParam','reccount')+' Listed');
$('#PlayerInformation').highlight($('#SearchThis').val(),true);
$('#SearchGo,#SearchHist').show();
$('#SearchOption,#SearchThis').removeAttr('disabled');
}
});

Результат запроса к базе данных:

{"page":"1","num":1,"cell":[{"X":"104,135","P":"Gaia of Vansterdam","C":"Hamster","F":"XXX","A":null,"S":"P","D":"01\/07\/15 13:08"},{"X":"102,115","P":"Gaia of Vansterdam","C":"Vansterdam","F":"XXX","A":null,"S":"P","D":"01\/07\/15 13:08"},{"X":"301,3","P":"VonVander","C":"VV1","F":"Von","A":"g144","S":"P","D":"01\/07\/15 13:08"}]}

До добавления page / num в JSON все работало нормально. Пока я не добавил страницу / номер, следуя инструкциям на сайте jqGRID, я не могу на всю жизнь понять, почему данные не отображаются в сетке. Был ли мой вывод JSON неправильным? Был ли неправильный макет PHP?

Заранее спасибо за помощь!
Шон

0

Решение

Я нашел свой недостаток и на основании того, что предложил Бармар, см. Выше пост, все правильно, только исправлено ниже:

Исправлено MySQL:

    $count = $ZD -> found_rows;
if($count > 0 && $limit > 0){$total_pages = ceil($count/$limit);}else{$total_pages = 0;}
if($page > $total_pages) $page = $total_pages;
$start = $limit * $page - $limit;
if($start < 0) $start = 0;

и метод массива:

$PullSearchInfoData = array('total' => (int)$total_pages,'page' => (int)$page,'records' => (int)$count,'rows' => $PullSearchInfoData);

Получил результат, который я искал, и правильно извлекает все данные в jqGRID 🙂
Спасибо за помощь Бармару!
Шон

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]