Ik heb een script waarmee ik een lijst kan toevoegen, binnen die lijst kan een gebruiker categorieen toevoegen en binnen elke categorie weer vragen.

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
        )

)
Maar wat betekent die sortorder dan precies? Ik denk dat je het jezelf onnodig moelijk maakt. Als je nu gewoon zorgt dat alles op volgorde staat voordat je submit, dan kun je toch gewoon van boven naar beneden door de lijst heen?

En als je van de elementen een type bijhoudt (categorie, vraag, whatever) dan kun je tevens tellers mee laten lopen die de volgorde tijdens de verwerking voor je uitrekenen zodat je die kunt opslaan, en op een later moment ook kunt hergebruiken om zo'n lijst bij te werken.

Er zal dan wat meer werk zitten in het opzetten van een dynamisch formulier zodat alles in de goede volgorde de deur uitgaat, maar dat lijkt me een stuk minder complex dan wat je hier probeert te doen. Eerlijk gezegd begrijp ik dat ook niet goed, geen idee hoe ik die sortorder moet interpreteren :p.
Ik heb het al opgelost, dacht inderdaad te moeilijk.
En wat was de oplossing dan? Die van Thomas? ;-)

Reageren