Avatar billede ditlev Juniormester
15. september 2011 - 08:55 Der er 5 kommentarer og
1 løsning

Tabeller på en række PHP/HTML

Hejsa
Er i gang med et projekt, hvor jeg vil lave nogle felter (tabeller) på linje. Jeg skal kunne bestemme rækkefølgen af felterne og et af felterne er specielt (et svarfelt).
Når jeg kører scriptet kommer felterne imidlertid på en linje vertikalt i stedet for horisontalt, og jeg kan ikke lige gennemskue hvordan jeg får dem til at ligge horisontalt.
Har prøvet at sætte dem ind i en tabel, men kunne ikke få det til at fungere.

Koden er her:

<?php
    function opgavefelt($nr){
        $nummer = $nr;
        $vandret = 7;
        $lodret = 7;

        echo '<table cellspacing="1" cellpadding="1" border="3" align=center>';
            for ($i=0; $i<$lodret; $i++) {
                echo '<tr>';
                    for ($n=0; $n<$vandret; $n++) {
                        // dit felt
                        echo "<td id=\"felt_".$nummer."_".$i."_".$n."\" width=\"15\" height=\"15\" style=\"background-color: Silver;\"></td>";
                    }
                echo '</tr>';
            }
        echo '</table>';
    }

    function svarfelt(){
        $vandret = 7;
        $lodret = 7;

        echo '<table cellspacing="1" cellpadding="1" border="3" align=center>';
            for ($i=0; $i<$lodret; $i++) {
                echo '<tr>';
                    for ($n=0; $n<$vandret; $n++) {
                        // dit felt
                        echo "<td id=\"svar_".$i."_".$n."\" width=\"15\" height=\"15\" style=\"background-color: Red;\"></td>";
                    }
                echo '</tr>';
            }
        echo '</table>';
    }
   
// Følgende felter skal placeres på linje, centreret på siden, rækkefølgen skal kunne ændres og antallet er mellem 3 og 5
// f.eks.: O=opgavefelt S=svarfelt: OOS eller SOOOO eller OSOO etc.
opgavefelt(2);
svarfelt();
opgavefelt(1);
opgavefelt(4);
opgavefelt(3);
?>

På forhånd tak :)
Avatar billede majbom Novice
15. september 2011 - 09:01 #1
du skal lade være med at lave <tr>, hvis du vil have dem på én linje...
Avatar billede ditlev Juniormester
15. september 2011 - 10:00 #2
Hvis jeg fjerner <tr> får jeg følgende resultat: Første <tr> flader felterne ud på en linje der dog stadig lejres oven på hinanden og ikke efter hinanden.
Den nederste <tr> har åbenbart ikke nogen betydning for scriptet, og lader til at kunne undværes.
Jeg kan således stadig ikke gennemskue hvorledes dette kan lade sig gøre - men det burde da være muligt!?
Avatar billede majbom Novice
15. september 2011 - 14:25 #3
ahh sorry - havde ikke læst din kode ordenligt, det er fordi du udskriver 5 tables efter hinanden, så kommer de under hinanden, da det er block-elementer.

du kan gøre sådan her:

<table>
    <tr>
        <td><?php opgavefelt(2); ?></td><td><?php svarfelt(); ?></td><td><?php opgavefelt(1); ?></td><td><?php opgavefelt(4); ?></td><td><?php opgavefelt(3); ?></td>
    </tr>
</table>
Avatar billede ditlev Juniormester
16. september 2011 - 09:17 #4
Hej splazz
Perfekt!
Super at der er nogle der har overblikket og kan hjælpe :)
Lav et svar, og du får point...
Avatar billede majbom Novice
16. september 2011 - 09:28 #5
kommer her :)
Avatar billede majbom Novice
16. september 2011 - 12:55 #6
tfp :)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester