Krijg antwoord laatste vraag niet uitgelezen (quiz PHP)

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Jelle Botman

Jelle Botman

27/03/2016 15:21:32
Quote Anchor link
Ik krijg het antwoord van de laatste vraag niet uitgelezen waardoor die automatisch goed word gerekend.

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
<?php
// Start the session
session_start();

if(isset($_SESSION['aantalvragen']))
{

$aantalvragen = $_SESSION['aantalvragen'];
$cijfer = $_SESSION['cijfer'];
$goed = $_SESSION['goed'];
$fout = $_SESSION['fout'];
$antwoord = $_SESSION['antwoord'];
}

else
{
    $aantalvragen = 0;
    $cijfer = 0;
    $goed = 0;
    $fout = 0;
}


if(isset($_SESSION["sommen"]))
{


$sommen = $_SESSION["sommen"];
}

else
{
$sommen = array();
}


if (isset($_GET['answer']))
{

$antwoordgebruiker = $_GET['answer'];
}
    
else
{
    $antwoordgebruiker = NULL;
}



//var_dump($sommen); uitlezen array
$w = 1;
$res = false;
if($aantalvragen<=4) //kleiner of gelijk aan 20
{
    $nummer = $aantalvragen - 1;
    $nummer1 = $aantalvragen + 1;
    $antwoordquery = mysql_query("SELECT * FROM vragen WHERE ID = '".$aantalvragen."'");
    $vraagdata = mysql_fetch_assoc($antwoordquery);
    
    $antwoordquery1 = mysql_query("SELECT * FROM vragen WHERE ID = '".$nummer."'");
    $vraagdata1 = mysql_fetch_assoc($antwoordquery1);
    $vraag = $vraagdata['vraag'];
    $antwoord = $vraagdata1['goede-antwoord'];
    if($antwoord == $antwoordgebruiker) //als het antwoord gelijk is
    {
    $goed = $goed + 1;
    $cijfer = $cijfer + 0.5;
    }

    else
    {
    $fout = $fout + 1;
    }

    
    $w = $w + 1;
    echo $antwoordgebruiker.' - '.$antwoord;
    echo'<div id="pagina">';
    echo '<div id="som">';
    echo '<form method="POST" >';
    echo '<b><h2>Vraag '.$nummer1.' / 20</h2></b>';
    echo '<h1>'.$vraag.'</h1>';
    echo '<table border="1" style="width: 40%;"><tr class="somans">';
    echo '<td style="width: 10%; background-color: orange;" > A:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=A"> '.$vraagdata['antwoord1'].'</td></tr></a>';
    echo '<tr class="somans"><td style="width: 10%; background-color: orange;"> B:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=B"> '.$vraagdata['antwoord2'].'</td></tr></a>';
    echo '<tr class="somans"><td style="width: 10%; background-color: orange;"> C:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=C"> '.$vraagdata['antwoord3'].'</td></tr></a>';
    echo '<tr class="somans"><td style="width: 10%; background-color: orange;"> D:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=D"> '.$vraagdata['antwoord4'].'</td></tr></a>';
    echo "</tr>";
    echo '</form>';
    echo '</div>';
    
    $aantalvragen++; // telt de vragen op









$_SESSION['antwoordgebruiker'] = $antwoordgebruiker;
$_SESSION['antwoord'] = $antwoord;
$_SESSION['aantalvragen'] = $aantalvragen;
$_SESSION['goed'] = $goed;
$_SESSION['fout'] = $fout;
$_SESSION['cijfer'] = $cijfer;
$_SESSION["sommen"] = $sommen;    

 
}


else
{
    

$sommen = $_SESSION["sommen"]; // uitslag
echo'<div id="pagina">';
echo '<div id="res">';

if($cijfer<5.5)
{

echo '<h1> Cijfer: </h1> <h1 id ="red"> '.$cijfer.'</h1>';
}

else
{
echo '<h1> Cijfer: </h1> <h1 id ="green"> '.$cijfer.'</h1>';
}

echo '<h2 id="green">Goed: '.$goed.'</h2>';
echo '<h2 id="red">Fout: '.$fout.'</h2><br/><br/>';
echo '<a href="index.php"><input type="submit" value="Terug naar Home"></a>';
echo '</div>';
echo '</div>';

session_destroy();

 // verwijderd de sessie zodat de sommen weer opnieuw gemaakt kunnen worden
}

?>


</body>
</html>



    
 
PHP hulp

PHP hulp

15/11/2024 14:30:27
 
Thomas van den Heuvel

Thomas van den Heuvel

28/03/2016 14:52:32
Quote Anchor link
Ik mis het volgende puzzelstukje: de data in de tabel "vragen".

Verder zou ik bovenstaande code wat verder uit elkaar trekken. Het onderscheid tussen het weergeven van een vraag en de verwerking ervan (en eventueel de functionaliteit voor paginering) zou je groter kunnen maken, zodat je deze ook (meer) in afzondering kunt behandelen.
 
Jelle Botman

Jelle Botman

29/03/2016 12:12:35
Quote Anchor link
de data in de tabel "vragen" is gewoon gevuld met 3 vragen
de kolomnamen zijn:
ID
vraag
antwoord1
antwoord2
antwoord3
antwoord4
goede-antwoord
 
- Ariën  -
Beheerder

- Ariën -

29/03/2016 12:25:05
Quote Anchor link
En wat als je nou opeens 5 vragen hebt? In ieder geval is de databaseopzet dus niet correct.
Tevens wou ik graag even opmerken dat de mysql_*() functies over een ruim jaar echt ter ziele zullen gaan als menig hosting over zal stappen op PHP7.
 
Jelle Botman

Jelle Botman

29/03/2016 12:30:36
Quote Anchor link
ja dat snap ik
maar ik gebruik voor nu even mysql_*() functies
ik maak een quiz dus ik maak het aantal vragen handmatig.
ik krijg alle antwoorden goed uitgelezen behalve de laatste
 
Thomas van den Heuvel

Thomas van den Heuvel

29/03/2016 13:22:02
Quote Anchor link
Ik heb geen idee wat er allemaal gebeurt maar wat mij in ieder geval vreemd overkomt is het volgende: het formulier heeft hardcoded hyperlinks, die alle verwijzen naar ?paginaNR=4. Dit lijkt mij de verkeerde insteek. Hiermee omzeil je ook de normale werking van het formulier, die hyperlinks maken in feite het formulier overbodig. Kies voor een van de twee (waarbij ik zou gaan voor een formulier).

Ik hoop ook dat je ons niet gaat vertellen dat je evenveel kopieën van dit script hebt als dat er pagina's/vragen zijn, elk met verschillende ?paginaNR=X hyperlinks... Dat is niet het idee van dynamische webpagina's.

Wat ik zou doen is eens een stapje terugnemen, een kritische blik werpen op de aanpak (met name van de navigatie), en vervolgens het een en ander anders opzetten.
 



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.