Dat werkt allemaal prima, dit is hoe een voorbeeld array er uit ziet waarmee ik data in de database stop:
Array
(
[Category 1] => Array
(
[0] => Question 1
[1] => Question 2
)
[Category 2] => Array
(
[0] => Question 1
)
[Category 3] => Array
(
[0] => question 1
)
)
Maar nu moet ik ook een sorteer volgorde toevoegen in de database (ik kan elementen sorteren met jQuery sort).
De hele lijst is een formulier die ik serialize:
$lijst = $( '#lijstform' ).serializeArray();
Die data stuur ik weer door naar mijn PHP script met Ajax.
Vervolgens doe ik dit in PHP om bovenstaande array ($store) te krijgen:
<?PHP
$arr = $_POST['lijst'];
// pull off first arr element which is the list name
$title = array_shift($arr);
foreach($arr as $a) {
$val = $a['value'];
// handle category
if($a['name'] == 'category[]') {
// save cat name
$currCat = $val;
// init questions array
$store[$currCat] = [];
}else {
// add question to question array
$store[$currCat][] = $val;
}
}
?>
Dit werkte allemaal prima voordat er een sorteervolgorde bij moest. Maar nu die ook wordt meegestuurd is dit hoe mijn array er bijvoorbeeld uit ziet:
Array
(
[Category 1] => Array
(
[0] => Question 1
[1] => Question 2
[2] => 1
)
[Category 2] => Array
(
[0] => Question 1
[1] => 2
)
[Category 3] => Array
(
[0] => question 1
[1] => 3
)
)
Zoals je ziet wordt de sorteervolgorde samen met de vraag onder elke categorie gestopt. Ik kan nu dus in mijn PHP script geen onderscheid maken tussen de twee, wanneer ik een lijst opsla wordt de volgorde als vraag opgeslagen in mijn database.
Eigenlijk zou ik de sorteervolgorde dus niet als oplopende key willen zien maar met een naam zoals [sortorder] zodat ik met een
<?PHP
echo $store[Category 1][sortorder];
?>
als resultaat gewoon 1 zie.
Hoe kan ik dat het beste doen?
Een categorie zou er dan zo uit komen te zien:
[Category 1] => Array
(
[0] => Question 1
[1] => Question 2
[sortorder] => 1
)
Dit is mijn array zoals die gepost is naar mijn PHP script, dit is dus hoe hij binnenkomt zonder dat ik nog een aanpassing heb gemaakt:
Array
(
[0] => Array
(
[name] => sortorder
[value] => 2
)
[1] => Array
(
[name] => category[]
[value] => gsdg
)
[2] => Array
(
[name] => question[]
[value] => dsgsdgsd
)
[3] => Array
(
[name] => sortorder
[value] => 1
)
[4] => Array
(
[name] => category[]
[value] => sdfgsd
)
[5] => Array
(
[name] => question[]
[value] => sdgsd
)
)